Browse Source

cmp模块代码初始化

yaoyu 1 month ago
parent
commit
74c2d87be7

+ 20 - 0
cmp/.classpath

@@ -0,0 +1,20 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<classpath>
+	<classpathentry kind="src" output="cmp/classes" path="cmp/src/public"/>
+	<classpathentry kind="src" output="cmp/classes" path="cmp/src/client"/>
+	<classpathentry kind="src" output="cmp/classes" path="cmp/src/private"/>
+	<classpathentry kind="src" output="cmp/classes" path="cmp/src/test"/>
+	<classpathentry kind="src" output="cmp/classes" path="cmp/resources"/>
+	<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
+	<classpathentry kind="con" path="com.yonyou.studio.udt.core.container/Ant_Library"/>
+	<classpathentry kind="con" path="com.yonyou.studio.udt.core.container/Product_Common_Library"/>
+	<classpathentry kind="con" path="com.yonyou.studio.udt.core.container/Middleware_Library"/>
+	<classpathentry kind="con" path="com.yonyou.studio.udt.core.container/Framework_Library"/>
+	<classpathentry kind="con" path="com.yonyou.studio.udt.core.container/Module_Public_Library"/>
+	<classpathentry kind="con" path="com.yonyou.studio.udt.core.container/Module_Client_Library"/>
+	<classpathentry kind="con" path="com.yonyou.studio.udt.core.container/Module_Private_Library"/>
+	<classpathentry kind="con" path="com.yonyou.studio.udt.core.container/Module_Lang_Library"/>
+	<classpathentry kind="con" path="com.yonyou.studio.udt.core.container/Generated_EJB"/>
+	<classpathentry kind="con" path="com.yonyou.studio.udt.core.container/NCCloud_Library"/>
+	<classpathentry kind="output" path="bin"/>
+</classpath>

+ 29 - 0
cmp/.project

@@ -0,0 +1,29 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<projectDescription>
+	<name>cmp</name>
+	<comment></comment>
+	<projects>
+	</projects>
+	<buildSpec>
+		<buildCommand>
+			<name>org.eclipse.jdt.core.javabuilder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+		<buildCommand>
+			<name>com.yonyou.studio.udt.core.builder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+		<buildCommand>
+			<name>com.yonyou.ria.g2.riabuilder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+	</buildSpec>
+	<natures>
+		<nature>org.eclipse.jdt.core.javanature</nature>
+		<nature>com.yonyou.studio.udt.core.nature</nature>
+		<nature>com.yonyou.ria.g2.rianature</nature>
+	</natures>
+</projectDescription>

+ 7 - 0
cmp/META-INF/module.xml

@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="gb2312"?>
+<module name="cmp">
+    <public>
+    </public>
+    <private>
+    </private>
+</module>

+ 23 - 0
cmp/bin/.project

@@ -0,0 +1,23 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<projectDescription>
+	<name>cmp</name>
+	<comment></comment>
+	<projects>
+	</projects>
+	<buildSpec>
+		<buildCommand>
+			<name>org.eclipse.jdt.core.javabuilder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+		<buildCommand>
+			<name>com.yonyou.studio.udt.core.builder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+	</buildSpec>
+	<natures>
+		<nature>org.eclipse.jdt.core.javanature</nature>
+		<nature>com.yonyou.studio.udt.core.nature</nature>
+	</natures>
+</projectDescription>

+ 7 - 0
cmp/bin/META-INF/module.xml

@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="gb2312"?>
+<module name="cmp">
+    <public>
+    </public>
+    <private>
+    </private>
+</module>

+ 3 - 0
cmp/cmp/classes/.gitignore

@@ -0,0 +1,3 @@
+/test.gitkeep
+/public.gitkeep
+/resources.gitkeep

BIN
cmp/cmp/classes/nc/ui/cmp/settlement/actions/SettleCombinPayAction.class


BIN
cmp/cmp/classes/nc/ui/cmp/settlement/actions/SettleListNetPayTransferAction.class


BIN
cmp/cmp/classes/nc/ui/cmp/settlement/actions/SettleNetPayTransferAction.class


BIN
cmp/cmp/classes/nc/ui/cmp/settlement/actions/ZfNewAction.class


+ 3 - 0
cmp/cmp/component.xml

@@ -0,0 +1,3 @@
+<component name="cmp" displayname="cmp">
+  <dependencies/>
+</component>

+ 1 - 0
cmp/cmp/resources/resources.gitkeep

@@ -0,0 +1 @@
+ユシホサキ�

+ 190 - 0
cmp/cmp/src/client/nc/ui/cmp/settlement/actions/SettleCombinPayAction.java

@@ -0,0 +1,190 @@
+package nc.ui.cmp.settlement.actions;
+
+import java.awt.event.ActionEvent;
+import java.util.List;
+
+import javax.swing.Action;
+
+import nc.bs.framework.common.NCLocator;
+import nc.bs.logging.Logger;
+import nc.cmp.settlement.validate.SettleValidate;
+import nc.cmp.utils.CmpUtils;
+import nc.cmp.utils.SettleUtils;
+import nc.funcnode.ui.action.INCAction;
+import nc.itf.cmp.ebank.ICMPPaymentService;
+import nc.itf.cmp.pub.CmpSelfDefButtonNameConst;
+import nc.itf.cmp.settlement.ISettlementQueryService;
+import nc.ui.cmp.netpayment.PaymentProc;
+import nc.ui.pub.beans.MessageDialog;
+import nc.ui.pub.beans.UIDialog;
+import nc.ui.uif2.ShowStatusBarMsgUtil;
+import nc.vo.cmp.BusiStatus;
+import nc.vo.cmp.SettleStatus;
+import nc.vo.cmp.settlement.SettlementAggVO;
+import nc.vo.cmp.settlement.SettlementBodyVO;
+import nc.vo.cmp.settlement.SettlementHeadVO;
+import nc.vo.cmp.settlement.international.util.SettleInternationalValidate;
+import nc.vo.cmp.validate.CMPValidate;
+import nc.vo.pub.BusinessException;
+import nc.vo.pub.lang.UFDouble;
+
+/**
+ * 合并支付
+ *
+ * @author wuzhwa
+ * @since v6.0
+ *
+ */
+public class SettleCombinPayAction extends SettleDefaultAction {
+
+	private static final long serialVersionUID = -4257102182028309094L;
+
+	public SettleCombinPayAction() {
+
+		setBtnName(CmpSelfDefButtonNameConst.getInstance().getConstBtnnameCombinpayName());
+		putValue(Action.SHORT_DESCRIPTION, getBtnName());
+		putValue(INCAction.CODE, "合并支付");/*-=notranslate=-*/
+
+	}
+
+	/*
+	 * (non-Javadoc)
+	 *
+	 * @see
+	 * nc.ui.cmp.settlement.actions.SettleDefaultAction#doAction(java.awt.event
+	 * .ActionEvent)
+	 *
+	 * @see V57 void
+	 * nc.ui.cmp.settlement.SettlementCardEventHandler.onBoCombinPay()
+	 */
+	@Override
+	public void doAction(ActionEvent e) throws Exception {
+		SettlementAggVO[] aggvos = null;
+		try {
+			Object obj = getValue();
+			if (obj.getClass().isArray()) {
+				aggvos = (SettlementAggVO[]) obj;
+			} else {
+				aggvos = new SettlementAggVO[] { (SettlementAggVO) obj };
+			}
+			StringBuffer error = new StringBuffer("业务单据编号:");
+			for (SettlementAggVO settlementAggVO : aggvos) {
+				//表头原币金额
+				UFDouble headPrimal = (UFDouble) settlementAggVO.getParentVO().getAttributeValue("primal");
+				//表体原币金额
+				UFDouble bodyPrimal = new UFDouble(0.00);
+				SettlementBodyVO [] settlementBodyVOs = (SettlementBodyVO[]) settlementAggVO.getChildrenVO();
+				for (SettlementBodyVO settlementBodyVO : settlementBodyVOs) {
+					bodyPrimal = bodyPrimal.add(settlementBodyVO.getPay_last());
+				}
+				if(headPrimal.compareTo(bodyPrimal) != 0) {
+					String billcode = (String) settlementAggVO.getParentVO().getAttributeValue("billcode");
+					error.append(billcode);
+					error.append(",");
+				}
+			}
+			if(error.length() != 7) {
+				throw new BusinessException(error+"表体合计金额不等于表头金额!");
+			}
+			List<SettlementAggVO> aggLst = SettleUtils.filterSettleInfo4NetSettleFlagUnSettle(aggvos);
+			if(aggLst.size()==0){
+				ShowStatusBarMsgUtil.showErrorMsg(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set1_0","03607set1-0078")/*@res "提示"*/,nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set1_0","03607set1-0079")/*@res "没有可网银支付的表体记录"*/, getModel().getContext());
+				return;
+			}
+			aggvos = aggLst.toArray(new SettlementAggVO[] {});
+			NCLocator.getInstance().lookup(ICMPPaymentService.class).validateCombinPay(aggvos);
+			this.getEdit().getClientSigner().checkIfCASign();
+//			this.getEdit().getClientSigner().identifyCA();
+
+			int i = MessageDialog.showYesNoDlg(getEdit(), nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID(
+					"3607set_0", "03607set-0029")/* @res "提示" */, nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID(
+					"3607set_0", "03607set-0050")/* @res "确定进行网上支付?" */);
+			if (i != UIDialog.ID_YES) {
+				return;
+			}
+			// 换用新的签名处理,在paymentproc里面,原因是签名也会弹出密码框,重复弹出了,更改实现方式。
+			Integer doZhifu = new PaymentProc().doZhifu(getEdit(), aggvos);
+			if(doZhifu == -1){
+				return;
+			}
+			List<String> pkLst = CmpUtils.makeList();
+			for (SettlementAggVO aggvo : aggvos) {
+				pkLst.add(aggvo.getParentVO().getPrimaryKey());
+			}
+			aggvos = NCLocator.getInstance().lookup(ISettlementQueryService.class).querySettlementAggVOsByPks(pkLst.toArray(new String[]{}));
+
+			if(!this.isListSelected()){
+				this.getEdit().setLoadBean(aggvos[0]);
+			}
+			getModel().directlyUpdate(aggvos);
+			this.getEdit().setValue(aggvos[0]);
+
+
+			ShowStatusBarMsgUtil.showStatusBarMsg(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0",
+					"03607set-0051")/*
+									 * @res "发送网银成功"
+									 */, getModel().getContext());
+		} catch (BusinessException be) {
+			Logger.error(be.getMessage(), be);
+			throw new BusinessException(be.getMessage());
+
+		}
+
+	}
+
+
+
+
+
+	@Override
+	protected boolean isActionEnable() {
+		SettlementAggVO[] aggvos = getSelectedAggVOs();
+		if (aggvos == null || aggvos.length == 0 || aggvos[0] == null) {
+			return false;
+		}
+		for (SettlementAggVO settlementAggVO : aggvos) {
+			SettlementAggVO currentAggvo = settlementAggVO;
+			SettlementHeadVO head = (SettlementHeadVO) currentAggvo.getParentVO();
+			// 收款类不能 支付
+			if (nc.vo.cmp.settlement.SettleEnumCollection.Direction.REC.VALUE.equals(head.getDirection())) {
+				return false;
+			}
+			if (head.getBusistatus() == null || !head.getBusistatus().equals(BusiStatus.Sign.getBillStatusKind())) {
+				// 非签字态的不能网上支付
+				return false;
+			}
+//			if (head.getSettlestatus() != null
+//					&& (head.getSettlestatus().equals(SettleStatus.PAYING.getStatus())
+//							|| head.getSettlestatus().equals(SettleStatus.CHANGEING.getStatus())
+//							|| head.getSettlestatus().equals(SettleStatus.RECEIVING.getStatus())
+//							|| head.getSettlestatus().equals(SettleStatus.SUCCESSPART.getStatus()) || head
+//							.getSettlestatus().equals(SettleStatus.SUCCESSSETTLE.getStatus()))) {
+//				/**
+//				 * 支付中,划账中、已经结算的不能支付
+//				 */
+//				return false;
+//			}
+
+			// 付款结算工资发放单据不能合并支付
+			if ("DS".equals(head.getPk_tradetype())) {
+				return false;
+			}
+			if (head.getPk_ftsbill() != null) {
+				// 资金组织生成的结算信息手工结算
+				return false;
+			}
+			if (SettleUtils.isExistInnerAccount(currentAggvo)) {
+				// 有内部账户的不能手工结算
+				return false;
+			}
+			for (SettlementBodyVO body : (SettlementBodyVO[])settlementAggVO.getChildrenVO()) {
+				if(body.getSettlestatus()!=null && body.getSettlestatus().equals(SettleStatus.SETTLERESET.getStatus())){
+					// 含有结算红冲的信息,不能反操作
+					return false;
+				}
+			}
+		}
+
+		return super.isActionEnable();
+	}
+}

+ 362 - 0
cmp/cmp/src/client/nc/ui/cmp/settlement/actions/SettleListNetPayTransferAction.java

@@ -0,0 +1,362 @@
+package nc.ui.cmp.settlement.actions;
+
+import java.awt.event.ActionEvent;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.LinkedList;
+import java.util.List;
+import java.util.Map;
+
+import javax.swing.Action;
+
+import nc.bs.framework.common.NCLocator;
+import nc.bs.logging.Logger;
+import nc.cmp.pub.exception.ExceptionHandler;
+import nc.cmp.settlement.validate.SettleValidate;
+import nc.cmp.utils.CmpUtils;
+import nc.cmp.utils.DataUtil;
+import nc.cmp.utils.SettleUtils;
+import nc.funcnode.ui.action.INCAction;
+import nc.itf.cmp.ebank.ICMPPaymentService;
+import nc.itf.cmp.pub.CmpSelfDefButtonNameConst;
+import nc.itf.cmp.settlement.ISettlementQueryService;
+import nc.pubitf.bbd.CurrtypeQuery;
+import nc.ui.pub.beans.MessageDialog;
+import nc.ui.pub.beans.UIDialog;
+import nc.ui.uif2.ShowStatusBarMsgUtil;
+import nc.ui.uif2.model.AbstractUIAppModel;
+import nc.vo.cmp.BusiStatus;
+import nc.vo.cmp.SettleStatus;
+import nc.vo.cmp.settlement.CheckException;
+import nc.vo.cmp.settlement.NetpayTransferVO;
+import nc.vo.cmp.settlement.PaymentInfoVO4Batch;
+import nc.vo.cmp.settlement.SettleEnumCollection.Direction;
+import nc.vo.cmp.settlement.SettlementAggVO;
+import nc.vo.cmp.settlement.SettlementBodyVO;
+import nc.vo.cmp.settlement.SettlementHeadVO;
+import nc.vo.cmp.settlement.international.util.SettleInternationalValidate;
+import nc.vo.cmp.validate.CMPValidate;
+import nc.vo.obm.pay.OnlinePaymentVO;
+import nc.vo.obm.sec.ObmCAInfoAccessor;
+import nc.vo.obm.sec.ObmCASignature;
+import nc.vo.pub.BusinessException;
+import nc.vo.pub.lang.UFDouble;
+import nc.vo.tmpub.util.TMCurrencyUtil;
+
+/**
+ * 结算信息列表界面网上转账按钮类
+ * 
+ * @author xwq
+ * 
+ */
+@SuppressWarnings("restriction")
+public class SettleListNetPayTransferAction extends SettleDefaultAction {
+
+	/**
+	 *
+	 */
+	private static final long serialVersionUID = 8899125168078379198L;
+
+	public SettleListNetPayTransferAction() {
+
+		setBtnName(CmpSelfDefButtonNameConst.getInstance().getConstBtnnameNetpaytransferName());
+		putValue(Action.SHORT_DESCRIPTION, getBtnName());
+		putValue(INCAction.CODE, "网上转账");/*-=notranslate=-*/
+
+	}
+
+	@Override
+	public void doAction(ActionEvent e) throws Exception {
+		SettlementAggVO[] selectedOperaDatas = getSelectedAggVOs();
+		
+		CheckException
+				.checkArgument(selectedOperaDatas == null,
+						nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0052")/*@res "请选择需要操作的单据"*/);
+		StringBuffer error = new StringBuffer("业务单据编号:");
+		for (SettlementAggVO settlementAggVO : selectedOperaDatas) {
+			//表头原币金额
+			UFDouble headPrimal = (UFDouble) settlementAggVO.getParentVO().getAttributeValue("primal");
+			//表体原币金额
+			UFDouble bodyPrimal = new UFDouble(0.00);
+			SettlementBodyVO [] settlementBodyVOs = (SettlementBodyVO[]) settlementAggVO.getChildrenVO();
+			for (SettlementBodyVO settlementBodyVO : settlementBodyVOs) {
+				bodyPrimal = bodyPrimal.add(settlementBodyVO.getPay_last());
+			}
+			if(headPrimal.compareTo(bodyPrimal) != 0) {
+				String billcode = (String) settlementAggVO.getParentVO().getAttributeValue("billcode");
+				error.append(billcode);
+				error.append(",");
+			}
+		}
+		if(error.length() != 7) {
+			throw new BusinessException(error+"表体合计金额不等于表头金额!");
+		}
+		List<SettlementAggVO> aggLst = SettleUtils.filterSettleInfo4NetSettleFlagUnSettle(selectedOperaDatas);
+		if (aggLst.size() == 0) {
+			ShowStatusBarMsgUtil
+					.showErrorMsg(
+							nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set1_0", "03607set1-0078")/*@res "提示"*/,
+							nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set1_0", "03607set1-0079")/*@res "没有可网银支付的表体记录"*/,
+							getModel().getContext());
+			return;
+		}
+		
+		selectedOperaDatas =aggLst.toArray(new SettlementAggVO[0]);
+
+		int len = selectedOperaDatas.length;
+
+		if (len > 1) {
+			for (Object aggvo : selectedOperaDatas) {
+				SettlementHeadVO settlementHeadVO = (SettlementHeadVO) ((SettlementAggVO) aggvo).getParentVO();
+				// 付款结算工资发放单据不能批量网上转账
+				if ("DS".equals(settlementHeadVO.getPk_tradetype())) {
+					ExceptionHandler.createandthrowException(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID(
+							"3607set1_0", "03607set1-0227"));
+				}
+			}
+		} else {
+			SettlementHeadVO head = (SettlementHeadVO) ((SettlementAggVO) selectedOperaDatas[0]).getParentVO();
+			// 工资发放单据,走特殊网银支付接口
+			String pk_tradetype = head.getPk_tradetype();
+			if ("DS".equals(pk_tradetype)) {
+
+				int num = MessageDialog
+						.showYesNoDlg(
+								getEdit(),
+								nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0029")/*@res "提示"*/,
+								nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0050")/*@res "确定进行网上支付?"*/);
+				if (num != UIDialog.ID_YES) {
+					return;
+				}
+				this.getEdit().getClientSigner().identifyCA();
+
+				doSalaryBillNetPay((SettlementAggVO) selectedOperaDatas[0]);
+				String id = selectedOperaDatas[0].getParentVO().getPrimaryKey();
+				
+				// 重新查一次,数据已经被更新。
+				SettlementAggVO[] newaggvos = NCLocator.getInstance().lookup(ISettlementQueryService.class).querySettlementAggVOsByPks(new String[]{id});
+				showNetPayTransferInfo(this.getModel() ,newaggvos);
+				return ;
+
+			}
+		}
+
+		SettlementAggVO[] aggvos = new SettlementAggVO[len];
+		List<String> ids = new LinkedList<String>();
+		for (int i = 0; i < len; i++) {
+			aggvos[i] = (SettlementAggVO) selectedOperaDatas[i];
+			ids.add(aggvos[i].getParentVO().getPrimaryKey());
+		}
+		
+		NCLocator.getInstance().lookup(ICMPPaymentService.class).validatePay(selectedOperaDatas);
+
+		int num = MessageDialog
+				.showYesNoDlg(
+						getEdit(),
+						nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0029")/*@res "提示"*/,
+						nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0050")/*@res "确定进行网上支付?"*/);
+		if (num != UIDialog.ID_YES) {
+			return;
+		}
+		
+
+		try {
+			// 执行批量网上转账
+			PaymentInfoVO4Batch[] retnsgs = doBatchZhuanzhang(aggvos);
+			
+			// 重新查一次,数据已经被更新。
+			SettlementAggVO[] newaggvos = NCLocator.getInstance().lookup(ISettlementQueryService.class)
+					.querySettlementAggVOsByPks(ids.toArray(new String[0]));
+			getModel().directlyUpdate(newaggvos);
+			// 如果是取消操作,则不提示信息
+			if (retnsgs == null) {
+				return;
+			}
+			showNetPayTransferInfo(this.getModel(), retnsgs);
+		} catch (BusinessException ex) {
+			Logger.error(ex.getMessage(), ex);
+			throw new BusinessException(ex.getMessage());
+		}
+	}
+
+	@Override
+	protected boolean isActionEnable() {
+
+		SettlementAggVO[] aggvos = getSelectedAggVOs();
+		if (aggvos == null || aggvos.length == 0 || aggvos[0] == null) {
+			return false;
+		}
+
+		for (SettlementAggVO settlementAggVO : aggvos) {
+			
+			
+
+			SettlementAggVO currentAggvo = settlementAggVO;
+			SettlementHeadVO head = (SettlementHeadVO) currentAggvo.getParentVO();
+			// 收款类不能 支付
+			if (nc.vo.cmp.settlement.SettleEnumCollection.Direction.REC.VALUE.equals(head.getDirection())) {
+				return false;
+			}
+
+			if (head.getBusistatus() == null || !head.getBusistatus().equals(BusiStatus.Sign.getBillStatusKind())) {
+				// 非签字态的不能网上支付
+				return false;
+			}
+			if (head.getPk_ftsbill() != null) {
+				// 资金组织生成的结算信息不能网上支付
+				return false;
+			}
+			if (SettleUtils.isExistInnerAccount(currentAggvo)) {
+				// 有内部账户的不能网上支付
+				return false;
+			}
+			for (SettlementBodyVO body : (SettlementBodyVO[]) settlementAggVO.getChildrenVO()) {
+				if (body.getSettlestatus() != null
+						&& body.getSettlestatus().equals(SettleStatus.SETTLERESET.getStatus())) {
+					// 含有结算红冲的信息,不能反操作
+					return false;
+				}
+			}
+		
+		}
+		return true;
+
+	}
+
+	/**
+	 * 工资发放网上支付
+	 * 
+	 * @param settlement
+	 * @throws BusinessException
+	 */
+	private void doSalaryBillNetPay(SettlementAggVO settlement) throws BusinessException {
+
+		ICMPPaymentService service = NCLocator.getInstance().lookup(ICMPPaymentService.class);
+		service.doNetTransfer4SalaryBill(DataUtil.getCurrentUser(), settlement);
+	}
+
+	// 提示网上支付成功信息
+	public static void showNetPayTransferInfo(AbstractUIAppModel model, PaymentInfoVO4Batch[] batch)
+			throws BusinessException {
+
+		int successCount = 0;
+		StringBuffer successMsg = new StringBuffer();
+
+		int failCount = 0;
+		StringBuffer failMsg = new StringBuffer();
+
+		for (PaymentInfoVO4Batch one : batch) {
+			if (one.getEx() != null) {
+				failCount++;
+				failMsg.append(((SettlementHeadVO) one.getAggvo().getParentVO()).getBillcode());
+				failMsg.append("\n");
+				failMsg.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0053")/*@res "错误原因:"*/);
+				failMsg.append(one.getEx().getMessage());
+				failMsg.append("\n");
+			} else {
+				successCount++;
+				successMsg.append(((SettlementHeadVO) one.getAggvo().getParentVO()).getBillcode());
+				successMsg.append(" ;");
+			}
+		}
+
+		StringBuffer allMsg = new StringBuffer();
+		if (successCount > 0) {
+			allMsg.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0051")/*@res "网上支付成功"*/)
+					.append(successCount)
+					.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0054")/*@res "张单据"*/);
+			allMsg.append("\n");
+			allMsg.append(successMsg);
+		} else {
+			allMsg.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0055")/*@res "网上支付失败"*/)
+					.append(successCount)
+					.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0054")/*@res "张单据"*/);
+			allMsg.append("\n");
+			allMsg.append(failMsg);
+		}
+		ShowStatusBarMsgUtil.showStatusBarMsg(allMsg.toString(), model.getContext());
+
+	}
+	
+	
+	
+	// 提示网上支付成功信息
+		public static void showNetPayTransferInfo(AbstractUIAppModel model, SettlementAggVO[] bills)
+				throws BusinessException {
+
+			Map<String, UFDouble> map = new HashMap<String, UFDouble>();
+			int size = 0;
+
+			for (SettlementAggVO aggvo : bills) {
+				size++;
+				SettlementBodyVO[] children = (SettlementBodyVO[]) aggvo.getChildrenVO();
+				for (SettlementBodyVO child : children) {
+					if (child.getDirection().equals(Direction.PAY.VALUE)
+							&& Integer.valueOf(SettleStatus.PAYFAIL.getStatus()).equals(child.getSettlestatus())) {
+						String currtype = child.getPk_currtype();
+						int orgCurrRateDigit = TMCurrencyUtil.getCurrtypeDigit(child.getPk_currtype());
+						UFDouble money = new UFDouble(child.getPay().getDouble(), orgCurrRateDigit);
+						if (map.containsKey(currtype)) {
+							UFDouble sumMoney = map.get(currtype);
+							map.put(currtype, sumMoney.add(money));
+
+						} else {
+							map.put(currtype, money);
+						}
+					}
+				}
+			}
+
+			if (size > 0) {
+				CurrtypeQuery currtypeQuery = CurrtypeQuery.getInstance();
+				StringBuffer sBuffer = new StringBuffer();
+				sBuffer.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0051")/*
+																													* @
+																													* res
+																													* "发送网银成功"
+																													*/)
+						.append(size)
+						.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0011")/*
+																													 * @
+																													 * res
+																													 * "张单据。"
+																													 */);
+				Iterator iterator = map.entrySet().iterator();
+				while (iterator.hasNext()) {
+					Map.Entry entry = (Map.Entry) iterator.next();
+					sBuffer.append("	").append(currtypeQuery.getCurrtypeName((String) entry.getKey())).append(": ");
+					sBuffer.append(entry.getValue()).append("\n");
+				}
+
+				ShowStatusBarMsgUtil.showStatusBarMsg(sBuffer.toString(), model.getContext());
+			}
+		}
+	
+	
+
+	/**
+	 * 执行批量支付
+	 * 
+	 * @param bills
+	 * @throws BusinessException
+	 */
+	private PaymentInfoVO4Batch[] doBatchZhuanzhang(SettlementAggVO[] aggvos) throws BusinessException {
+		OnlinePaymentDelegator delegator = new OnlinePaymentDelegator();
+		NetpayTransferVO[] netPayTransferVOs = delegator.doBatchBulu(aggvos, getEdit());
+		if(CmpUtils.isListNull(netPayTransferVOs)){ 
+			return null;
+		}
+		List<OnlinePaymentVO> lst = CmpUtils.makeList();
+		for (NetpayTransferVO netpayTransferVO : netPayTransferVOs) {
+			lst.addAll(CmpUtils.covertArraysToList(netpayTransferVO.getOnlinePaymentVOs()));			
+		}
+		
+		// 传递签名信息
+		ObmCASignature obmca = new ObmCASignature();
+		// 只要支付前签名处理就行,验签交给网银处理
+		 obmca.signPayInfo(lst.toArray(new OnlinePaymentVO[]{}), new ObmCAInfoAccessor(), DataUtil.getCurrentUser());
+		
+		return delegator.doBatchNetTransfer(netPayTransferVOs);
+	}
+
+}

+ 324 - 0
cmp/cmp/src/client/nc/ui/cmp/settlement/actions/SettleNetPayTransferAction.java

@@ -0,0 +1,324 @@
+package nc.ui.cmp.settlement.actions;
+
+import java.awt.event.ActionEvent;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+import javax.swing.Action;
+
+import nc.bs.framework.common.NCLocator;
+import nc.cmp.settlement.validate.SettleValidate;
+import nc.cmp.utils.CmpUtils;
+import nc.cmp.utils.DataUtil;
+import nc.cmp.utils.SettleUtils;
+import nc.funcnode.ui.action.INCAction;
+import nc.itf.cmp.ebank.ICMPPaymentService;
+import nc.itf.cmp.pub.CmpSelfDefButtonNameConst;
+import nc.itf.cmp.settlement.ISettlementQueryService;
+import nc.pubitf.bbd.CurrtypeQuery;
+import nc.ui.cmp.netpayment.PaymentProc;
+import nc.ui.pub.beans.MessageDialog;
+import nc.ui.pub.beans.UIDialog;
+import nc.ui.uif2.ShowStatusBarMsgUtil;
+import nc.ui.uif2.model.AbstractUIAppModel;
+import nc.vo.cmp.BusiStatus;
+import nc.vo.cmp.SettleStatus;
+import nc.vo.cmp.settlement.SettleEnumCollection.Direction;
+import nc.vo.cmp.settlement.international.util.SettleInternationalValidate;
+import nc.vo.cmp.settlement.SettlementAggVO;
+import nc.vo.cmp.settlement.SettlementBodyVO;
+import nc.vo.cmp.settlement.SettlementHeadVO;
+import nc.vo.cmp.validate.CMPValidate;
+import nc.vo.pub.BusinessException;
+import nc.vo.pub.CircularlyAccessibleValueObject;
+import nc.vo.pub.lang.UFDouble;
+import nc.vo.pubapp.pattern.data.ValueUtils;
+import nc.vo.pubapp.pattern.pub.MathTool;
+import nc.vo.tmpub.util.TMCurrencyUtil;
+
+/**
+ * 网上转账
+ * 
+ * @author wuzhwa
+ * @since v6.0
+ * 
+ */
+public class SettleNetPayTransferAction extends SettleDefaultAction {
+
+	private static final long serialVersionUID = -4257102182028309094L;
+
+	public SettleNetPayTransferAction() {
+
+		setBtnName(CmpSelfDefButtonNameConst.getInstance().getConstBtnnameNetpaytransferName());
+		putValue(Action.SHORT_DESCRIPTION, getBtnName());
+		putValue(INCAction.CODE, "网上转账");/*-=notranslate=-*/
+
+	}
+
+	/*
+	 * (non-Javadoc)
+	 *
+	 * @see
+	 * nc.ui.cmp.settlement.actions.SettleDefaultAction#doAction(java.awt.event
+	 * .ActionEvent)
+	 *
+	 * @see V57 void
+	 * nc.ui.cmp.settlement.SettlementCardEventHandler.onBoNetTransfer()
+	 */
+	@Override
+	public void doAction(ActionEvent e) throws Exception {
+
+		/**
+		 * 已经结算成功的单据 不能进行网上转账 网上支付的单据结算方式不能为空,且应为勾选网银属性的档案 否则支付时给出提示
+		 * 单据状态应为已生效,才能进行网上转账 单据必须录入收付款银行账户,且账户应开通网银支付 否则支付时给出提示
+		 * 符合条件的单据,点网上转账之后,弹出补录网银信息对话框,如已录入网银信息,可在此进行修改
+		 * 补录网银信息之后确定,单据将被传到资金的网上银行,同时单据状态变为付款中 支付确认单确认为成功 结算状态结算成功
+		 * 测试多条单据的支付,部分确认为成功,部分确认为失败 每个单据的结算状态正确回写
+		 */
+
+		SettlementAggVO aggvo = (SettlementAggVO) getEdit().getValue();
+		if (aggvo == null) {
+			return;
+		}
+		//表头原币金额
+		UFDouble headPrimal = (UFDouble) aggvo.getParentVO().getAttributeValue("primal");
+		//表体原币金额
+		UFDouble bodyPrimal = new UFDouble(0.00);
+		SettlementBodyVO [] settlementBodyVOs = (SettlementBodyVO[]) aggvo.getChildrenVO();
+		for (SettlementBodyVO settlementBodyVO : settlementBodyVOs) {
+			bodyPrimal = bodyPrimal.add(settlementBodyVO.getPay_last());
+		}
+		if(headPrimal.compareTo(bodyPrimal) != 0) {
+			String billcode = (String) aggvo.getParentVO().getAttributeValue("billcode");
+			throw new BusinessException("业务单据编号:"+billcode+",表体合计金额不等于表头金额!");
+		}
+		List<SettlementAggVO> aggLst = SettleUtils.filterSettleInfo4NetSettleFlagUnSettle(aggvo);
+		if (aggLst.size() == 0) {
+			ShowStatusBarMsgUtil
+					.showErrorMsg(
+							nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set1_0", "03607set1-0078")/*@res "提示"*/,
+							nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set1_0", "03607set1-0079")/*@res "没有可网银支付的表体记录"*/,
+							getModel().getContext());
+			return;
+		}
+		aggvo = aggLst.get(0);
+		validate(aggvo);
+		SettlementHeadVO head = (SettlementHeadVO) aggvo.getParentVO();
+		// 工资发放单据,走特殊网银支付接口
+		String pk_tradetype = head.getPk_tradetype();
+		// 换用新的签名处理,在paymentproc里面
+		
+		if ("DS".equals(pk_tradetype)) {
+			// 强制CA
+			this.getEdit().getClientSigner().identifyCA();
+		}else{
+			this.getEdit().getClientSigner().checkIfCASign();
+		}
+		// CAAuthor.INSTANCE.author4Net();
+		int num = MessageDialog.showYesNoDlg(getEdit(),
+				nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0029")/*
+																									 * @
+																									 * res
+																									 * "提示"
+																									 */,
+				nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0050")/*
+																									 * @
+																									 * res
+																									 * "确定进行网上支付?"
+																									 */);
+		if (num != UIDialog.ID_YES) {
+			return;
+		}
+
+		// SettlementHeadVO head=(SettlementHeadVO)aggvo.getParentVO();
+		// 转账操作
+		try {
+
+			// 工资发放单据,走特殊网银支付接口
+			
+			if ("DS".equals(pk_tradetype)) {
+				doSalaryBillNetPay(aggvo);
+
+			} else {
+				Integer rtn = new PaymentProc().doZhuanzhang(getEdit(), aggvo);
+				if (rtn == -1) {
+					return;
+				}
+			}
+			
+
+			// 提示网上支付成功信息
+			showNetPayTransferInfo(this.getModel(), new SettlementAggVO[] { aggvo });
+
+		} catch (BusinessException ex) {
+			throw new BusinessException(ex);
+		}finally{
+			aggvo = NCLocator.getInstance().lookup(
+					ISettlementQueryService.class).querySettlementAggVOsByPks(
+					new String[] { aggvo.getParentVO().getPrimaryKey() })[0];
+
+			this.getEdit().setValue(aggvo);
+			this.getEdit().setLoadBean(aggvo);
+			getModel().directlyUpdate(aggvo);
+		}
+		/**
+		 * ====================================================================
+		 * =====
+		 */
+
+	}
+
+	/**
+	 * 工资发放网上支付
+	 * 
+	 * @param settlement
+	 * @throws BusinessException
+	 */
+	private void doSalaryBillNetPay(SettlementAggVO settlement) throws BusinessException {
+
+		ICMPPaymentService service = NCLocator.getInstance().lookup(ICMPPaymentService.class);
+		service.doNetTransfer4SalaryBill(DataUtil.getCurrentUser(), settlement);
+	}
+
+	/**
+	 * 校验
+	 * 
+	 * @throws BusinessException
+	 */
+	private void validate(SettlementAggVO aggvo) throws BusinessException {
+
+		// 校验rmb业务
+		// SettleValidate.validateCurrency(aggvo);
+		// 校验支付业务数据
+		SettleValidate.validatePayData(aggvo);
+		// 是否启用
+		SettleValidate.validateOBM(new SettlementAggVO[] { aggvo });
+		// 校验单据状态
+		SettleValidate.validateNetPayState(aggvo);
+		// 网上支付的单据单据行校验
+		SettleValidate.validateNetPayNegativeRow(aggvo);
+
+		SettleValidate.validateCombin(new SettlementAggVO[] { aggvo }, true);
+
+		// 校验供应商是否已经付款冻结
+		SettleValidate.validateSupplier(aggvo);
+
+		SettleValidate.dataIntegralityValidate(aggvo);
+		SettleInternationalValidate.checkInternationalNotSupportedOperate(aggvo);
+
+		CMPValidate.validate(aggvo);
+
+	}
+
+	// 提示网上支付成功信息
+	public static void showNetPayTransferInfo(AbstractUIAppModel model, SettlementAggVO[] bills)
+			throws BusinessException {
+
+		Map<String, UFDouble> map = new HashMap<String, UFDouble>();
+		int size = 0;
+
+		for (SettlementAggVO aggvo : bills) {
+			size++;
+			SettlementBodyVO[] children = (SettlementBodyVO[]) aggvo.getChildrenVO();
+			for (SettlementBodyVO child : children) {
+				if (child.getDirection().equals(Direction.PAY.VALUE)
+						&& Integer.valueOf(SettleStatus.PAYFAIL.getStatus()).equals(child.getSettlestatus())) {
+					String currtype = child.getPk_currtype();
+					int orgCurrRateDigit = TMCurrencyUtil.getCurrtypeDigit(child.getPk_currtype());
+					UFDouble money = new UFDouble(child.getPay().getDouble(), orgCurrRateDigit);
+					if (map.containsKey(currtype)) {
+						UFDouble sumMoney = map.get(currtype);
+						map.put(currtype, sumMoney.add(money));
+
+					} else {
+						map.put(currtype, money);
+					}
+				}
+			}
+		}
+
+		if (size > 0) {
+			CurrtypeQuery currtypeQuery = CurrtypeQuery.getInstance();
+			StringBuffer sBuffer = new StringBuffer();
+			sBuffer.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0051")/*
+																												* @
+																												* res
+																												* "发送网银成功"
+																												*/)
+					.append(size)
+					.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0011")/*
+																												 * @
+																												 * res
+																												 * "张单据。"
+																												 */);
+			Iterator iterator = map.entrySet().iterator();
+			while (iterator.hasNext()) {
+				Map.Entry entry = (Map.Entry) iterator.next();
+				sBuffer.append("	").append(currtypeQuery.getCurrtypeName((String) entry.getKey())).append(": ");
+				sBuffer.append(entry.getValue()).append("\n");
+			}
+
+			ShowStatusBarMsgUtil.showStatusBarMsg(sBuffer.toString(), model.getContext());
+		}
+	}
+
+	@Override
+	protected boolean isActionEnable() {
+
+		// return super.isActionEnable();
+		SettlementAggVO[] aggvos = getSelectedAggVOs();
+		if (CmpUtils.isListNull(aggvos)) {
+			return false;
+		}
+		for (SettlementAggVO settlementAggVO : aggvos) {
+			SettlementAggVO currentAggvo = settlementAggVO;
+			SettlementHeadVO head = (SettlementHeadVO) currentAggvo.getParentVO();
+			// 收款类不能 支付
+			if (nc.vo.cmp.settlement.SettleEnumCollection.Direction.REC.VALUE.equals(head.getDirection())) {
+				return false;
+			}
+
+			if (head.getBusistatus() == null || !head.getBusistatus().equals(BusiStatus.Sign.getBillStatusKind())) {
+				// 非签字态的不能网上支付
+				return false;
+			}
+			// 按表体支付,不在约束支付状态
+			// if (head.getSettlestatus() != null
+			// &&
+			// (head.getSettlestatus().equals(SettleStatus.PAYING.getStatus())
+			// ||
+			// head.getSettlestatus().equals(SettleStatus.CHANGEING.getStatus())
+			// ||
+			// head.getSettlestatus().equals(SettleStatus.RECEIVING.getStatus())
+			// ||
+			// head.getSettlestatus().equals(SettleStatus.SUCCESSPART.getStatus())
+			// || head
+			// .getSettlestatus().equals(SettleStatus.SUCCESSSETTLE.getStatus())))
+			// {
+			// /**
+			// * 支付中,划账中、已经结算的不能支付
+			// */
+			// return false;
+			// }
+			if (head.getPk_ftsbill() != null) {
+				// 资金组织生成的结算信息不能网上支付
+				return false;
+			}
+			if (SettleUtils.isExistInnerAccount(currentAggvo)) {
+				// 有内部账户的不能网上支付
+				return false;
+			}
+			for (SettlementBodyVO body : (SettlementBodyVO[]) settlementAggVO.getChildrenVO()) {
+				if (body.getSettlestatus() != null
+						&& body.getSettlestatus().equals(SettleStatus.SETTLERESET.getStatus())) {
+					// 含有结算红冲的信息,不能反操作
+					return false;
+				}
+			}
+		}
+
+		return true;
+	}
+}

+ 221 - 0
cmp/cmp/src/client/nc/ui/cmp/settlement/actions/ZfNewAction.java

@@ -0,0 +1,221 @@
+package nc.ui.cmp.settlement.actions;
+
+import java.awt.Container;
+import java.awt.event.ActionEvent;
+import java.util.List;
+import nc.bs.framework.common.NCLocator;
+import nc.bs.logging.Logger;
+import nc.cmp.utils.CmpUtils;
+import nc.cmp.utils.DataUtil;
+import nc.cmp.utils.SettleUtils;
+import nc.desktop.ui.WorkbenchEnvironment;
+import nc.itf.cmp.ebank.copy.ICopyCMPPaymentService;
+import nc.itf.cmp.ebank.ICMPPaymentService;
+import nc.itf.cmp.settlement.ISettlementQueryService;
+import nc.pubitf.obm.IObmBuluUI;
+import nc.ui.pub.beans.MessageDialog;
+import nc.ui.uif2.ShowStatusBarMsgUtil;
+import nc.vo.cmp.BusiStatus;
+import nc.vo.cmp.SettleStatus;
+import nc.vo.cmp.settlement.NetpayTransferVO;
+import nc.vo.cmp.settlement.SettleEnumCollection;
+import nc.vo.cmp.settlement.SettlementAggVO;
+import nc.vo.cmp.settlement.SettlementBodyVO;
+import nc.vo.cmp.settlement.SettlementHeadVO;
+import nc.vo.ml.NCLangRes4VoTransl;
+import nc.vo.obm.pay.OnlinePaymentVO;
+import nc.vo.obm.pay.PaymentRetMsg;
+import nc.vo.obm.sec.ObmCAInfoAccessor;
+import nc.vo.obm.sec.ObmCASignature;
+import nc.vo.pub.BusinessException;
+import nc.vo.pub.lang.UFDate;
+import nc.vo.pub.lang.UFDouble;
+
+public class ZfNewAction
+  extends SettleDefaultAction
+{
+  ICopyCMPPaymentService paymentService = (ICopyCMPPaymentService)NCLocator.getInstance().lookup(ICopyCMPPaymentService.class);
+  private SettlementAggVO[] aggVOs;
+  private IObmBuluUI ebank;
+	
+	
+  private static final long serialVersionUID = 8899125168078379198L;
+  
+  public ZfNewAction()
+  {
+    setBtnName("객데북깻連마");
+    putValue("ZfNewAction", getBtnName());
+    putValue("Code", "객데북깻連마");
+  }
+  
+  public void doAction(ActionEvent e)
+    throws Exception
+  {
+    SettlementAggVO[] aggvos = null;
+    try
+    {
+      Object obj = getValue();
+      if (obj.getClass().isArray()) {
+        aggvos = (SettlementAggVO[])obj;
+      } else {
+        aggvos = new SettlementAggVO[] { (SettlementAggVO)obj };
+      }
+      
+      StringBuffer error = new StringBuffer("撚蛟데앴긍뵀:");
+		for (SettlementAggVO settlementAggVO : aggvos) {
+			//깊庫覩귑쏜띨
+			UFDouble headPrimal = (UFDouble) settlementAggVO.getParentVO().getAttributeValue("primal");
+			//깊竟覩귑쏜띨
+			UFDouble bodyPrimal = new UFDouble(0.00);
+			SettlementBodyVO [] settlementBodyVOs = (SettlementBodyVO[]) settlementAggVO.getChildrenVO();
+			for (SettlementBodyVO settlementBodyVO : settlementBodyVOs) {
+				bodyPrimal = bodyPrimal.add(settlementBodyVO.getPay_last());
+			}
+			if(headPrimal.compareTo(bodyPrimal) != 0) {
+				String billcode = (String) settlementAggVO.getParentVO().getAttributeValue("billcode");
+				error.append(billcode);
+				error.append(",");
+			}
+		}
+		if(error.length() != 7) {
+			throw new BusinessException(error+"깊竟북셕쏜띨꼇된黨깊庫쏜띨!");
+		}
+      
+      List<SettlementAggVO> aggLst = SettleUtils.filterSettleInfo4NetSettleFlagUnSettle(aggvos);
+      if (aggLst.size() == 0)
+      {
+        ShowStatusBarMsgUtil.showErrorMsg(NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set1_0", "03607set1-0078"), NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set1_0", "03607set1-0079"), getModel().getContext());
+        return;
+      }
+      aggvos = (SettlementAggVO[])aggLst.toArray(new SettlementAggVO[0]);
+      ((ICMPPaymentService)NCLocator.getInstance().lookup(ICMPPaymentService.class)).validateCombinPay(aggvos);
+	      getEdit().getClientSigner().checkIfCASign();
+      
+
+      int i = MessageDialog.showYesNoDlg(getEdit(), NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0029"), NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0050"));
+      if (i != 4) {
+        return;
+      }
+      Integer doZhifu = doZhifu(getEdit(), aggvos);
+      if (doZhifu.intValue() == -1) {
+        return;
+      }
+      List<String> pkLst = CmpUtils.makeList();
+      for (SettlementAggVO aggvo : aggvos) {
+        pkLst.add(aggvo.getParentVO().getPrimaryKey());
+      }
+      aggvos = ((ISettlementQueryService)NCLocator.getInstance().lookup(ISettlementQueryService.class)).querySettlementAggVOsByPks((String[])pkLst.toArray(new String[0]));
+      if (!isListSelected()) {
+        getEdit().setLoadBean(aggvos[0]);
+      }
+      getModel().directlyUpdate(aggvos);
+      getEdit().setValue(aggvos[0]);
+      
+
+      ShowStatusBarMsgUtil.showStatusBarMsg(NCLangRes4VoTransl.getNCLangRes().getStrByID("3607set_0", "03607set-0051"), getModel().getContext());
+    }
+    catch (BusinessException be)
+    {
+      Logger.error(be.getMessage(), be);
+      throw new BusinessException(be.getMessage());
+    }
+  }
+  
+  protected boolean isActionEnable()
+  {
+    SettlementAggVO[] aggvos = getSelectedAggVOs();
+    if ((aggvos == null) || (aggvos.length == 0) || (aggvos[0] == null)) {
+      return false;
+    }
+    for (SettlementAggVO settlementAggVO : aggvos)
+    {
+      SettlementAggVO currentAggvo = settlementAggVO;
+      SettlementHeadVO head = (SettlementHeadVO)currentAggvo.getParentVO();
+      if (SettleEnumCollection.Direction.REC.VALUE.equals(head.getDirection())) {
+        return false;
+      }
+      if ((head.getBusistatus() == null) || (!head.getBusistatus().equals(Integer.valueOf(BusiStatus.Sign.getBillStatusKind())))) {
+        return false;
+      }
+      if ("DS".equals(head.getPk_tradetype())) {
+        return false;
+      }
+      if (head.getPk_ftsbill() != null) {
+        return false;
+      }
+      if (SettleUtils.isExistInnerAccount(currentAggvo)) {
+        return false;
+      }
+      for (SettlementBodyVO body : (SettlementBodyVO[])settlementAggVO.getChildrenVO()) {
+        if ((body.getSettlestatus() != null) && (body.getSettlestatus().equals(Integer.valueOf(SettleStatus.SETTLERESET.getStatus())))) {
+          return false;
+        }
+      }
+    }
+    return super.isActionEnable();
+  }
+  
+  public Integer doZhifu(Container parent, SettlementAggVO[] aggs)
+		    throws BusinessException
+		  {
+		    setContainer(parent);
+		    setAggVOs(aggs);
+		    
+		    NetpayTransferVO transferVO = this.paymentService.doCombinPayDelOBMLog(aggs, this.operaterID);
+
+		    PaymentRetMsg[] rets = getEbankUI().doObmBusinessBulu(parent, transferVO.getOnlinePaymentVOs(), 3, "CMP");
+		    
+		    int len = rets == null ? 0 : rets.length;
+		    if ((len == 0) || (rets[0].getTranflag() == null) || (!rets[0].getTranflag().equals(Integer.valueOf(0)))) {
+		      return Integer.valueOf(-1);
+		    }
+		    for (PaymentRetMsg paymentRetMsg : rets)
+		    {
+		      if (paymentRetMsg.getRetFlag() == 2) {
+		        throw new BusinessException(paymentRetMsg.getMsg());
+		      }
+		      if (paymentRetMsg.getRetFlag() == 1) {
+		        return null;
+		      }
+		    }
+		    setCAInfoToPaymentVO(transferVO.getOnlinePaymentVOs());
+		    this.paymentService.savePaymentAndDealCombim(transferVO, this.operaterID, this.busidate);
+		    return Integer.valueOf(0);
+		  }
+  
+  public SettlementAggVO[] getAggVOs()
+  {
+    return this.aggVOs;
+  }
+  
+  private final String operaterID = WorkbenchEnvironment.getInstance().getLoginUser().getPrimaryKey();
+  private final UFDate busidate = WorkbenchEnvironment.getInstance().getBusiDate();
+
+  
+  public void setAggVOs(SettlementAggVO[] aggVOs)
+  {
+    this.aggVOs = aggVOs;
+  }
+  private void setCAInfoToPaymentVO(OnlinePaymentVO[] onlinepaymentvos)
+  {
+    ObmCASignature obmca = new ObmCASignature();
+    
+    obmca.signPayInfo(onlinepaymentvos, new ObmCAInfoAccessor(), DataUtil.getCurrentUser());
+  }
+  
+  protected IObmBuluUI getEbankUI()
+  {
+    if (this.ebank == null) {
+      try
+      {
+        Class cl = Class.forName("nc.ui.ebank.out.EbankEntrance");
+        this.ebank = ((IObmBuluUI)cl.newInstance());
+      }
+      catch (Exception ex)
+      {
+        throw new RuntimeException(ex);
+      }
+    }
+    return this.ebank;
+  }
+}

+ 1 - 0
cmp/cmp/src/private/resources.gitkeep

@@ -0,0 +1 @@
+ユシホサキ�

+ 1 - 0
cmp/cmp/src/public/public.gitkeep

@@ -0,0 +1 @@
+ユシホサキ�

+ 1 - 0
cmp/cmp/src/test/test.gitkeep

@@ -0,0 +1 @@
+ユシホサキ�