/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatCHPrcRkInfSksiCalc
*	ソースファイル名	：JBSbatCHPrcRkInfSksiCalc.java
*	作成者				：富士通　
*	作成日				：2012年02月08日
*＜機能概要＞
*　料金履歴情報作成（料金計算）部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2012/02/08   富士通		新規作成
*********************************************************************/
package eo.business.service;


import eo.business.common.JACbatDebugLogUtil;
import eo.business.common.JBSbatBusinessService;
import eo.business.common.JCCBatCommon;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatServiceInterfaceMap;
import eo.framework.item.JBSbatOutputItem;
import eo.business.common.JBSbatMatchServiceInterface;
import eo.business.util.file.JBSbatCHIFM059;
import eo.business.util.file.JBSbatCHIFM096;
import eo.common.constant.JACStrConst;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatCHPrcRkInfSksiCalc extends JBSbatBusinessService implements JBSbatMatchServiceInterface
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** キーマッチ処理フラグ*/
	private boolean matchProcFlg;

	/** マスタファイル処理フラグ*/
	private boolean mastProcFlg;

	/** トランファイル処理フラグ*/
	private boolean tranProcFlg;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/
	
	/** マッチフラグ（前回マッチングの結果）*/
	private boolean isMacthBef = false;
	
	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][initial]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][opeDate=" + super.opeDate + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][freeItem=" + super.freeItem + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][initial]");
		
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param mastMap　入力電文
	 * @param tranMap　入力電文
	 * @param outputInItem  入力情報
	 * @return JBSbatOutputItem 出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap mastMap, JBSbatServiceInterfaceMap tranMap, JBSbatOutputItem outputInItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute]");
		assert mastMap != null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute][mastMap=" + mastMap.getMap().toString() + "]") : true;
		assert tranMap != null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute][tranMap=" + tranMap.getMap().toString() + "]") : true;
		
		// 入力Ｍのみ存在する
		if (mastMap != null && tranMap == null)
		{
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｍのみ存在する]");
			if (!isMacthBef)
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｍのみ存在する][退避．マッチフラグ　＝　false　の場合]");
				// 料金履歴情報作成（Ｍのみ）
				makeOutputInfo(outputInItem, mastMap);
			}
			
			this.isMacthBef = false;
			this.setMastProcFlg(true);
		}
		// 入力Ｔのみ存在する
		else if (mastMap == null && tranMap != null)
		{
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｔのみ存在する]");
			this.isMacthBef = false;
			this.setTranProcFlg(true);
		}
		// 入力Ｍ、入力Ｔともに存在する
		else
		{
			// マッチングキー取得
			String mastSeikyKeiNoKey 	= mastMap.getString(JBSbatCHIFM059.SEIKY_KEI_NO);				// ステータス更新対象情報．請求契約番号
			String tranSeikyKeiNoKey 	= tranMap.getString(JBSbatCHIFM096.SEIKY_KEI_NO);				// 料金対応記録登録情報．請求契約番号
			
			// 入力Ｍ＝入力Ｔ（マッチ）
			if (mastSeikyKeiNoKey.compareTo(tranSeikyKeiNoKey) == 0)
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｍ、入力Ｔともに存在する][入力Ｍ＝入力Ｔ（マッチ）]");
				
				// 料金履歴情報作成（マッチ）
				makeOutputInfoMatch(outputInItem, tranMap);
				this.isMacthBef = true;
				this.setMatchProcFlg(true);
			}
			// 入力Ｍ＜入力Ｔ
			else if (mastSeikyKeiNoKey.compareTo(tranSeikyKeiNoKey) < 0)
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｍ、入力Ｔともに存在する][入力Ｍ＜入力Ｔ]");
				if (!isMacthBef)
				{
					// 料金履歴情報作成（Ｍのみ）
					assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｍ、入力Ｔともに存在する][退避．マッチフラグ　＝　false　の場合]");
					makeOutputInfo(outputInItem, mastMap);
				}
				this.isMacthBef = false;
				this.setMastProcFlg(true);
			}
			// 入力Ｍ＞入力Ｔ
			else
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][入力Ｍ、入力Ｔともに存在する][入力Ｍ＞入力Ｔ]");
				this.isMacthBef = false;
				this.setTranProcFlg(true);
			}
		}
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][execute]");
		return outputInItem;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}
	
	/**
	 * 料金履歴情報作成（マッチ）
	 * @param outputInItem　出力情報
	 * @param tranMap　入力電文（トラン）
	 * @throws Exception
	 */
	private void makeOutputInfoMatch(JBSbatOutputItem outputInItem, JBSbatServiceInterfaceMap tranMap) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][makeOutputInfoMatch]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][makeOutputInfoMatch][tranMap=" + tranMap.getMap().toString() + "]");
		
		// 料金履歴情報作成（マッチ）
		JBSbatServiceInterfaceMap outMap = new JBSbatServiceInterfaceMap();
		
		// 入力マスタ情報を全項目コピー
		outMap.setMap(tranMap.getMap());
		
		// 出力フラグ設定
		outMap.setOutFlg(true);
		
		// 出力処理
		outputInItem.addOutMapList(outMap);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][makeOutputInfoMatch][outputItem = " + outMap.getMap().toString() + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][makeOutputInfoMatch]");
	}

	/**
	 * 料金履歴情報作成（Ｍのみ）
	 * @param outputInItem　出力情報
	 * @param mastMap　入力電文（マスタ）
	 * @throws Exception
	 */
	private void makeOutputInfo(JBSbatOutputItem outputInItem, JBSbatServiceInterfaceMap mastMap) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][makeOutputInfo]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][makeOutputInfo][mastMap=" + mastMap.getMap().toString() + "]");
		
		// 料金履歴情報作成（Ｍのみ）
		JBSbatServiceInterfaceMap outMap = new JBSbatServiceInterfaceMap();
		
		// 01.請求契約番号
		outMap.set(JBSbatCHIFM096.SEIKY_KEI_NO, 				mastMap.get(JBSbatCHIFM059.SEIKY_KEI_NO));
		// 02.サービス契約番号
		outMap.set(JBSbatCHIFM096.SVC_KEI_NO, 					null);
		// 03.対応年月日時分秒
		outMap.set(JBSbatCHIFM096.TAIO_DTM, 					JCCBatCommon.getSysDateTimeStamp());
		// 04.料金対応記録種別コード
		outMap.set(JBSbatCHIFM096.PRC_TAIO_KIROK_SBT_CD, 		JACStrConst.TKRK_SBT_PRC_CALC);
		// 05.料金対応記録種別詳細コード
		outMap.set(JBSbatCHIFM096.PRC_TAIO_KIROK_SBT_DTL_CD, 	null);
		// 06.記録対象年月
		outMap.set(JBSbatCHIFM096.KIROK_TG_YM, 					mastMap.get(JBSbatCHIFM059.SEIKY_YM));
		// 07.督促番号
		outMap.set(JBSbatCHIFM096.TOKUSOKU_NO, 					null);
		// 08.督促異動番号
		outMap.set(JBSbatCHIFM096.TOKUSOKU_IDO_NO, 				null);
		// 09.請求番号
		outMap.set(JBSbatCHIFM096.SEIKY_NO,						null);
		// 10.金庫番号
		outMap.set(JBSbatCHIFM096.KNK_NO, 						null);
		// 11.債権番号
		outMap.set(JBSbatCHIFM096.SAIKEN_NO, 					null);
		// 12.入金番号
		outMap.set(JBSbatCHIFM096.NYUKIN_NO, 					null);
		// 13.電子ファイル管理番号
		outMap.set(JBSbatCHIFM096.EFILE_KANRI_NO, 				null);
		// 14.対応履歴連動対象フラグ
		outMap.set(JBSbatCHIFM096.TAIORRKI_RENDO_TG_FLG, 		JACStrConst.TAIORRKI_RENDO_TG_FLG_HIHYOJI);
		// 15.変更前金額
		outMap.set(JBSbatCHIFM096.AMNT_CHBF, 					null);
		// 16.変更後金額
		outMap.set(JBSbatCHIFM096.AMNT_CHAF, 					null);
		// 17.変更前督促ステータス
		outMap.set(JBSbatCHIFM096.TOKUSOKU_STAT_CHBF, 			null);
		// 18.変更後督促ステータス
		outMap.set(JBSbatCHIFM096.TOKUSOKU_STAT_CHAF, 			null);
		// 19.変更前料金コースコード
		outMap.set(JBSbatCHIFM096.PCRS_CD_CHBF, 				null);
		// 20.変更後料金コースコード
		outMap.set(JBSbatCHIFM096.PCRS_CD_CHAF, 				null);
		// 21.変更前料金サービスコード
		outMap.set(JBSbatCHIFM096.PRC_SVC_CD_CHBF, 				null);
		// 22.変更後料金サービスコード
		outMap.set(JBSbatCHIFM096.PRC_SVC_CD_CHAF, 				null);
		// 23.変更前金庫料金項目コード
		outMap.set(JBSbatCHIFM096.KNK_PRC_KMK_CD_CHBF, 			null);
		// 24.変更後金庫料金項目コード
		outMap.set(JBSbatCHIFM096.KNK_PRC_KMK_CD_CHAF, 			null);
		// 25.督促メールパターン
		outMap.set(JBSbatCHIFM096.TOKUSOKU_ML_PTN_CD, 			null);
		// 26.変更前補償費扱いフラグ
		outMap.set(JBSbatCHIFM096.COMPENSATION_FLG_CHBF, 		null);
		// 27.変更後補償費扱いフラグ
		outMap.set(JBSbatCHIFM096.COMPENSATION_FLG_CHAF, 		null);
		// 28.変更前引抜き種別コード
		outMap.set(JBSbatCHIFM096.HKNK_SBT_CD_CHBF, 			null);
		// 29.変更後引抜き種別コード
		outMap.set(JBSbatCHIFM096.HKNK_SBT_CD_CHAF, 			null);
		// 30.記事
		outMap.set(JBSbatCHIFM096.KIJI, 						null);
		
		// 出力フラグ設定
		outMap.setOutFlg(true);
		
		// 出力処理
		outputInItem.addOutMapList(outMap);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][makeOutputInfo][outputItem = " + outMap.getMap().toString() + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][makeOutputInfo]");
	}
	
	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][terminal]");
		
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][terminal]");
		
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	
	/**
	 * @return mastProcFlg を戻します。
	 */
	public boolean isMastProcFlg()
	{
		return mastProcFlg;
	}

	/**
	 * @return matchProcFlg を戻します。
	 */
	public boolean isMatchProcFlg()
	{
		return matchProcFlg;
	}

	/**
	 * @return tranProcFlg を戻します。
	 */
	public boolean isTranProcFlg()
	{
		return tranProcFlg;
	}

	/**
	 * @param mast_ProcFlg 設定する mastProcFlg。
	 */
	public void setMastProcFlg(boolean mast_ProcFlg)
	{
		this.mastProcFlg = mast_ProcFlg;
	}

	/**
	 * @param match_ProcFlg 設定する matchProcFlg。
	 */
	public void setMatchProcFlg(boolean match_ProcFlg)
	{
		this.matchProcFlg = match_ProcFlg;
	}

	/**
	 * @param tran_ProcFlg 設定する tranProcFlg。
	 */
	public void setTranProcFlg(boolean tran_ProcFlg)
	{
		this.tranProcFlg = tran_ProcFlg;
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
}
