/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatACKaikHjCvsNkDtSksi
*	ソースファイル名	：JBSbatACKaikHjCvsNkDtSksi.java
*	作成者				：富士通　
*	作成日				：2012年04月21日
*＜機能概要＞
*　会計用法人コンビニ入金データ作成部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2012/04/21   富士通		新規作成
*	v5.00.00	2013/09/25  FJ)黒木		【OM-2013-0002514】抽出不正対応
*	v6.00.00	2014/01/21  FJ)江森		【OM-2013-0005234】対象データ抽出条件追加,出力定義変更
*	v8.00.00	2014/03/14  FJ)北端		【TG1-2014-0000004】増税に伴う印紙税対象金額の取得処理実装
*********************************************************************/
package eo.business.service;

import java.math.BigDecimal;
import java.util.HashMap;
import java.util.Map;

import eo.business.common.JACbatDebugLogUtil;
import eo.business.common.JACbatParamUtil;
import eo.business.common.JACbatSchdlUtil;
import eo.business.common.JBSbatBusinessService;
import eo.business.common.JCCBatCommon;
import eo.business.util.file.JBSbatACIFM143;
import eo.business.util.file.JBSbatCHIFM105;
import eo.business.util.table.JBSbatCH_M_KAIK_UCWK_CHG;
import eo.common.constant.JACStrConst;
import eo.common.util.JCHStampDutyUtil;
import eo.framework.db.JBSbatSQLAccess;
import eo.framework.item.JBSbatCommonDBInterface;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.item.JBSbatServiceInterfaceMap;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatACKaikHjCvsNkDtSksi extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(会計内訳変換)*/
	private static final String D_TBL_NAME_CH_M_KAIK_UCWK_CHG = "CH_M_KAIK_UCWK_CHG";

	/** SQL定義キー(AC_SELECT_003)*/
	private static final String CH_M_KAIK_UCWK_CHG_AC_SELECT_003 = "AC_SELECT_003";

	/** テーブルアクセスクラス(会計内訳変換)*/
	private JBSbatSQLAccess db_CH_M_KAIK_UCWK_CHG = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/

	/** 業務パラメータ(印紙税計算用金額)*/
	private BigDecimal acInsCalcAmnt = null;

	/** 業務パラメータ(通常用のメーカーコード)*/
	private String chMakerCodeNormal = null;
	
	/** 会計計上月 */
	private String kaikYm = null;
	
	/** [0].月初日、[1].コンビニ締め日 */
	private String[] useStrEnd = null;

	/** 月末日 */
	private String endYmd = null;
	
	/** 前月会計計上月 **/
	private String bfKaikYm = null;
	
	/** [0].前月初日、[1]前回コンビニ締め日 **/
	private String[] bfStrUseEnd = null;

	/** 収入印紙マスクラグ判定金額退避マップ */
	private Map<String, BigDecimal> inshiMaskAmntMap = new HashMap<String, BigDecimal> ();

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_CH_M_KAIK_UCWK_CHG = new JBSbatSQLAccess(commonItem, D_TBL_NAME_CH_M_KAIK_UCWK_CHG);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
		
		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 + "]");
		
		//  業務パラメータ取得
		JACbatParamUtil paramUtil = new JACbatParamUtil(commonItem);
		
		this.chMakerCodeNormal = paramUtil.getGyoumuParameter(JACStrConst.WKPRA_CH_MAKER_CODE_NORMAL);

		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][chMakerCodeNormal=" + this.chMakerCodeNormal + "]");
		paramUtil.close();
		
		// スケジュール取得
		JACbatSchdlUtil schdlUtil = new JACbatSchdlUtil(commonItem);
		// 会計計上月を取得
		this.kaikYm = schdlUtil.getBillDate(super.opeDate, JACStrConst.EVENT_CD_KAIK_SHORI_YMD);
		// 月初日、コンビニ締め日を取得
		this.useStrEnd = schdlUtil.getUseStrEnd(this.kaikYm, JACStrConst.EVENT_CD_USE_STAYMD, JACStrConst.EVENT_CD_CVS_SIME_YMD);
		// 月末日を取得
		this.endYmd = schdlUtil.getUseStrEnd(this.kaikYm, JACStrConst.EVENT_CD_USE_STAYMD, JACStrConst.EVENT_CD_USE_ENDYMD)[1];
		// 前月会計計上月を取得
		this.bfKaikYm = JCCBatCommon.addMonth(this.kaikYm.concat(JACStrConst.STR_OF_MONTH), -1).substring(0, 6);
		// 前回コンビニ締め日を取得
		this.bfStrUseEnd = schdlUtil.getUseStrEnd(this.bfKaikYm, JACStrConst.EVENT_CD_USE_STAYMD, JACStrConst.EVENT_CD_CVS_SIME_YMD);
		
		assert 	this.kaikYm != null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][会計計上月=" + this.kaikYm + "]") : true;
		assert 	this.useStrEnd != null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][月初日=" + this.useStrEnd[0]+"｜コンビニ締め日="+this.useStrEnd[1] + "]") : true;
		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][月末日=" + this.endYmd +"]");
		assert 	this.bfKaikYm != null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][前月会計計上月=" + this.bfKaikYm + "]") : true;
		assert 	this.bfStrUseEnd != null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][前月初日=" + this.bfStrUseEnd[0]+"｜前回コンビニ締め日="+this.bfStrUseEnd[1] + "]") : true;
		schdlUtil.close();
		
		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][initial]");
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute]");
		assert 	inMap != null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute][inMap=" + inMap.getMap().toString() + "]") : true;
		
		// 出力対象判定
		// 収納管理入金情報・収納日　≦　月末日　かつ
		// 収納管理入金情報・収納日　＞　前回コンビニ締め日　かつ
		// 収納管理入金情報・入金取消年月日　＝　空文字　が出力対象
		if(inMap.getString(JBSbatCHIFM105.OUT_ORG_SHUNO_YMD).compareTo(this.endYmd) <= 0 &&
			inMap.getString(JBSbatCHIFM105.OUT_ORG_SHUNO_YMD).compareTo(this.bfStrUseEnd[1]) > 0 &&
			inMap.getString(JBSbatCHIFM105.NYUKIN_CL_YMD).equals(JACStrConst.KARA_MOJI))
		{
			// 収納管理入金情報．収納日を基準日として印紙対象金額を取得する
			String shunoYMD = inMap.getString(JBSbatCHIFM105.OUT_ORG_SHUNO_YMD);
			this.acInsCalcAmnt = getInshiMaskAmount(shunoYMD);
		}
		else
		{
			// 次レコードへ
			return null;
		}
		
		JBSbatOutputItem outputItem = new JBSbatOutputItem();
		
		// 会計内訳コード取得
		this.selectChMKaikUcwkChg(inMap);
		
		// 結果取得
		JBSbatCommonDBInterface dbMap = db_CH_M_KAIK_UCWK_CHG.selectNext();
		if(dbMap == null)
		{
			// 取得件数が０件の場合、次レコードへ
			return null;
		}

		while(dbMap != null)
		{
			// 会計用法人コンビニ入金データ作成
			this.createOutMap(inMap, dbMap, outputItem);
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][dbMap=" + dbMap.getMap().toString() + "]");
			
			dbMap = db_CH_M_KAIK_UCWK_CHG.selectNext();
		}
		
		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][execute]");
		return outputItem;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_CH_M_KAIK_UCWK_CHG.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
		
		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][terminal]");
		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][terminal]");
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/

	/**
	 * SQLKEY(AC_SELECT_003)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	会計内訳種別コード
	 *		 	入金経路コード
	 *		 	収納機関コード
	 *		 	コンビニ支払予定年月日判定結果コード
	 *		 	予約適用年月日
	 *		 	会計内訳変換適用開始年月日
	 *		 	会計内訳変換適用終了年月日
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeCH_M_KAIK_UCWK_CHG_AC_SELECT_003(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());
		paramList.setValue(param[2].toString());
		paramList.setValue(param[3].toString());
		paramList.setValue(param[4].toString());
		paramList.setValue(param[5].toString());
		paramList.setValue(param[6].toString());

		// DBアクセスを実行します
		db_CH_M_KAIK_UCWK_CHG.selectBySqlDefine(paramList, CH_M_KAIK_UCWK_CHG_AC_SELECT_003);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/

	/**
	 * 会計内訳コード取得を取得します。
	 * 
	 * @param inMap 		入力電文
	 * @throws Exception 　業務サービス内で発生した例外全般
	 */
	private void selectChMKaikUcwkChg(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][selectChMKaikUcwkChg]");
		
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		
		paramList.setValue(JACStrConst.KAIK_UCWK_SBT_HOJIN_CVS);					// 会計内訳種別コード（会計用法人コンビニ）
		paramList.setValue(inMap.getString(JBSbatCHIFM105.NYUKIN_ROUTE_CD));		// 入金経路コード
		paramList.setValue(inMap.getString(JBSbatCHIFM105.SHUNOKIKAN_CD));			// 収納機関コード 
		paramList.setValue(this.jdgCsvRsvYmdJdgeCd(inMap));							// コンビニ支払予定年月日判定結果コード
		paramList.setValue(super.opeDate);											// 予約適用年月日 
		paramList.setValue(super.opeDate);											// 会計内訳変換適用開始年月日 
		paramList.setValue(super.opeDate);											// 会計内訳変換適用終了年月日 
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][selectChMKaikUcwkChg][paramList=" + paramList.getList().toString() + "]");

		// SQL実行
		executeCH_M_KAIK_UCWK_CHG_AC_SELECT_003(paramList.getList().toArray());
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][selectChMKaikUcwkChg]");
	}
	
	/**
	 * 入力情報と月初日、月末日、コンビニ締め日をもとに、
	 * コンビニ支払予定年月日判定結果コードの値を判定し、その結果を返却します。
	 * 
	 * @param inMap 入力電文
	 * @return String コンビニ支払予定年月日判定結果コード（判定結果："1"（前月収納当月入金）[入力．収納日　＜　初期処理．月初日、且つ、入力．入金予定日　≦　初期処理．月末日の場合]
	 * 																 ："2"（当月収納当月入金）[初期処理．月初日　≦　入力．収納日　≦　初期処理．月末日、且つ、入力．入力予定日　≦　初期処理．月末日の場合]
	 * 																 ："3"（当月収納翌月入金）[初期処理．コンビニ締め日　＜　入力．収納日、且つ、初期処理．月末日　＜　入力．入金予定日の場合]
	 * 																 ：""（空文字）　　　　　 [上記以外]
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	private String jdgCsvRsvYmdJdgeCd(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][jdgCsvRsvYmdJdgeCd]");
		
		// 返却値
		String rtnStr = JACStrConst.KARA_MOJI;
		
		// 入力．収納日
		String outOrgShunoYmd = inMap.getString(JBSbatCHIFM105.OUT_ORG_SHUNO_YMD);
		// 入力．入金予定日
		String nkinRsvd = inMap.getString(JBSbatCHIFM105.NKIN__RSVD);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][jdgCsvRsvYmdJdgeCd][入力．収納日=" + outOrgShunoYmd + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][jdgCsvRsvYmdJdgeCd][入力．入金予定日" + nkinRsvd + "]");
		// 入力．収納日　＜　初期処理．月初日、
		// 且つ、入力．入金予定日　≦　初期処理．月末日の場合
		if(outOrgShunoYmd.compareTo(this.useStrEnd[0]) < 0
			&& nkinRsvd.compareTo(this.endYmd) <= 0)
		{
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][jdgCsvRsvYmdJdgeCd][入力．収納日　＜　初期処理．月初日、且つ、入力．入金予定日　≦　初期処理．月末日の場合]");
			
			rtnStr = JACStrConst.CSV_RSV_YMD_JUDGE_CD_1;
		}
		// 初期処理．月初日　≦　入力．収納日　≦　初期処理．月末日、
		// 且つ、入力．入力予定日　≦　初期処理．月末日の場合
		else if(outOrgShunoYmd.compareTo(this.useStrEnd[0]) >= 0 && outOrgShunoYmd.compareTo(this.endYmd) <= 0
			&& nkinRsvd.compareTo(this.endYmd) <= 0)
		{
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][jdgCsvRsvYmdJdgeCd][初期処理．月初日　≦　入力．収納日　≦　初期処理．月末日、且つ、入力．入力予定日　≦　初期処理．月末日の場合]");
			
			rtnStr = JACStrConst.CSV_RSV_YMD_JUDGE_CD_2;
		}
		// 初期処理．コンビニ締め日　＜　入力．収納日、
		// 且つ、初期処理．月末日　＜　入力．入金予定日の場合
		else if(this.useStrEnd[1].compareTo(outOrgShunoYmd) < 0
			&& this.endYmd.compareTo(nkinRsvd) < 0)
		{
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][jdgCsvRsvYmdJdgeCd][初期処理．コンビニ締め日　＜　入力．収納日、且つ、初期処理．月末日　＜　入力．入金予定日の場合]");
			
			rtnStr = JACStrConst.CSV_RSV_YMD_JUDGE_CD_3;
		}
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][jdgCsvRsvYmdJdgeCd][コンビニ支払予定年月日判定結果コード=" + rtnStr + "]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][jdgCsvRsvYmdJdgeCd]");
		return rtnStr;
	}
	
	
	/**
	 * 会計用法人コンビニ入金データを作成し、出力します。
	 * @param inMap 		入力電文
	 * @param dbMap 		会計内訳変換
	 * @param outputItem 	出力電文
	 * 
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	private void createOutMap(JBSbatServiceInterfaceMap inMap, JBSbatCommonDBInterface dbMap, JBSbatOutputItem outputItem) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][createOutput]");
		
		// 会計用法人コンビニ入金データ
		JBSbatServiceInterfaceMap outMap = new JBSbatServiceInterfaceMap();
		// 入金額を取得
		BigDecimal nyukinAmnt = inMap.getBigDecimal(JBSbatCHIFM105.NYUKIN_AMNT);
		
		// 会計内訳種別コード
		outMap.setString(JBSbatACIFM143.KAIK_UCWK_SBT_CD, dbMap.getString(JBSbatCH_M_KAIK_UCWK_CHG.KAIK_UCWK_SBT_CD));
		// 会計内訳種別詳細コード
		outMap.setString(JBSbatACIFM143.KAIK_UCWK_SBT_DTL_CD, dbMap.getString(JBSbatCH_M_KAIK_UCWK_CHG.KAIK_UCWK_SBT_DTL_CD));
		// 請求契約番号
		outMap.setString(JBSbatACIFM143.SEIKY_KEI_NO, inMap.getString(JBSbatCHIFM105.SEIKY_KEI_NO));
		// 会計計上月
		outMap.setString(JBSbatACIFM143.KAIK_YM, this.kaikYm);
		// 会計内訳コード
		outMap.setString(JBSbatACIFM143.KAIK_UCWK_CD, dbMap.getString(JBSbatCH_M_KAIK_UCWK_CHG.KAIK_UCWK_CD));
		// コンビニ支払予定年月日
		outMap.setString(JBSbatACIFM143.CVSTORE_PAY_RSV_YMD, inMap.getString(JBSbatCHIFM105.NKIN__RSVD));
		// 件数
		outMap.setString(JBSbatACIFM143.CNT, JACStrConst.CNT_ONE);
		// 金額
		outMap.setString(JBSbatACIFM143.AMNT, nyukinAmnt);
		// 請求番号
		outMap.setString(JBSbatACIFM143.SEIKY_NO, inMap.getString(JBSbatCHIFM105.SEIKY_NO));
		// 外部組織収納年月日
		outMap.setString(JBSbatACIFM143.OUT_ORG_SHUNO_YMD, inMap.getString(JBSbatCHIFM105.OUT_ORG_SHUNO_YMD));
		// 入金処理年月日
		outMap.setString(JBSbatACIFM143.NYUKIN_TRN_YMD, inMap.getString(JBSbatCHIFM105.NYUKIN_TRN_YMD));
		// 入金経路コード
		outMap.setString(JBSbatACIFM143.NYUKIN_ROUTE_CD, inMap.getString(JBSbatCHIFM105.NYUKIN_ROUTE_CD));
		// 収納機関コード
		outMap.setString(JBSbatACIFM143.SHUNOKIKAN_CD, inMap.getString(JBSbatCHIFM105.SHUNOKIKAN_CD));
		// ＥＡＮメーカーコード
		outMap.setString(JBSbatACIFM143.EAN_MAKER_CD, this.chMakerCodeNormal);
		// コンビニ支払予定年月日判定結果コード
		outMap.setString(JBSbatACIFM143.CVS_PAY_RSV_YM_JDG_RSLT_CD, dbMap.getString(JBSbatCH_M_KAIK_UCWK_CHG.CVS_PAY_RSV_YM_JDG_RSLT_CD));
		
		// 印紙税対象件数
		if(this.acInsCalcAmnt.compareTo(nyukinAmnt) <= 0)
		{
			// 印紙税計算用金額≦入金額の場合
			outMap.setString(JBSbatACIFM143.INS_TRGT_CNT, JACStrConst.CNT_ONE);
			assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][createOutput][印紙税計算用金額≦入金額]");
		}
		else
		{
			// 上記以外の場合
			outMap.setString(JBSbatACIFM143.INS_TRGT_CNT, JACStrConst.CNT_ZERO);
			assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][createOutput][印紙税計算用金額>入金額]");
		}

		// レコード出力判定フラグの設定
		outMap.setOutFlg(true);

		// 出力レコード情報を設定する
		assert 	inMap != null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][createOutput][outputMap=" + outMap.getMap().toString() + "]") : true;
		outputItem.addOutMapList(outMap);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][createOutput]");
	}

	/**
	 * 印紙対象金額取得
	 * 
	 * @param baseDate 基準年月日（YYYYMMDD）
	 * @return BigDecimal 印紙対象金額
	 * @throws Exception 
	 */
	private BigDecimal getInshiMaskAmount(String baseDate) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][getInshiMaskAmount]");
		
		String baseDateYM = baseDate.substring(0, 6);
		BigDecimal receiptAmnt = inshiMaskAmntMap.get(baseDateYM);
		if(receiptAmnt == null)
		{
			// 未取得の場合は取得してMapに退避する
			receiptAmnt = new BigDecimal(JCHStampDutyUtil.getTaxableAmount(JACStrConst.CALLER_BATCH, commonItem.getConnection(), baseDate));
			inshiMaskAmntMap.put(baseDateYM, receiptAmnt);
		}
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][getInshiMaskAmount]");
		return receiptAmnt;
	}

}
