/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatACChrgTgKapSvkeiInfMake
*	ソースファイル名	：JBSbatACChrgTgKapSvkeiInfMake.java
*	作成者				：富士通　
*	作成日				：2012年09月27日
*＜機能概要＞
*　課金対象割賦サービス契約情報作成部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v4.00		2012/09/27   FJ）冨井	【ANK-0546-00-00】新規作成
*               2012/12/01   FJ) 東海林	課金判定条件誤りを修正
*	v4.01.00	2012/12/05   FJ）加島	【IT1-2012-0002307】課金対象判断、利用日数取得、ファイル編集処理修正
*	v5.00.00	2013/07/11   FJ) 岡田	【TG1-2013-0000662】マスタ参照基準日水平展開対応
*********************************************************************/
package eo.business.service;

import java.math.BigDecimal;
import java.util.HashMap;

import eo.business.common.JACBatCommon;
import eo.business.common.JACbatDebugLogUtil;
import eo.business.common.JACbatRknBusinessUtil;
import eo.business.common.JACbatSchdlUtil;
import eo.business.common.JBSbatBusinessService;
import eo.business.util.file.JBSbatACIFI030;
import eo.business.util.file.JBSbatACIFM166;
import eo.business.util.table.JBSbatAC_M_PRC_SVC_KANRI;
import eo.common.constant.JACStrConst;
import eo.common.constant.JPCBatchMessageConstant;
import eo.common.util.JPCUtilCommon;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatServiceInterfaceMap;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.item.JBSbatCommonDBInterface;
import eo.framework.application.JBSbatBusinessException;
import eo.framework.db.JBSbatSQLAccess;
import eo.framework.util.JBSbatDateUtil;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatACChrgTgKapSvkeiInfMake extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(料金サービス管理)*/
	private static final String D_TBL_NAME_AC_M_PRC_SVC_KANRI = "AC_M_PRC_SVC_KANRI";

	/** SQL定義キー(AC_SELECT_001)*/
	private static final String AC_M_PRC_SVC_KANRI_AC_SELECT_001 = "AC_SELECT_001";

	/** テーブルアクセスクラス(料金サービス管理)*/
	private JBSbatSQLAccess db_AC_M_PRC_SVC_KANRI = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/
	
	/** 退避．料金サービス管理マップ */
	private HashMap<String, String> tmpPrcSvcKanriMap = null;
	
	/** 退避．請求年月 */
	private String tmpSeikyYm = null;
	
	/** 退避．請求年月月初日 */
	private String tmpSeikyYmStaDay = null;
	
	/** 退避．請求年月月末日 */
	private String tmpSeikyYmEndDay = null;
	
	/** 退避．請求年月前月末日 */
	private String tmpSeikyYmBfEndDay = null;
	
	/** 群月末日 */
	private String wk_GunEnd = null;
	
	/** 固定値：日付差分フラグ（両日付を差に含める） */
	private static final String DIFF_NAI_FLG 		= "1";
	
	/** 料金サービスコード桁数 */
	private static final int PRC_SVC_CD_LEN 		= 12;

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_AC_M_PRC_SVC_KANRI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_AC_M_PRC_SVC_KANRI);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/

		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 + "]");
		
		// 料金スケジュール定義アクセス部品初期処理
		JACbatSchdlUtil schdlUtil = new JACbatSchdlUtil(commonItem);
		
		try
		{
			// 請求年月を取得する
			String seikyYm = schdlUtil.getBillDate(super.opeDate, JACStrConst.EVENT_CD_RYOKIN_KEISAN_YMD);
			
			// 請求年月から、利用開始終了日取得
			String[] strEndYmd = schdlUtil.getUseStrEnd(seikyYm, JACStrConst.EVENT_CD_USE_STAYMD, JACStrConst.EVENT_CD_USE_ENDYMD);
			
			this.wk_GunEnd = strEndYmd[1];	// 群月末日
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][initial][群月末日：" + wk_GunEnd + "]");
		}
		finally
		{
			// 料金スケジュール定義アクセス部品クローズ
			schdlUtil.close();
		}
		
		// 料金サービス管理マップを作成
		this.makePrcSvcKanriMap();
		
		// スケジュール取得
		this.getSchdlInfo();
		
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute][inMap=" + inMap.getMap().toString() + "]");
		
		// 課金対象割賦サービス契約情報作成
		// 課金対象判断
		if(!this.isChrgTrgtJdg(inMap))
		{
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][処理対象外]");
			// 処理を終了し次のレコードを読み込む
			return null;
		}
		
		// 利用日数取得
		String[] useDayCntData = this.getUseDayCnt(inMap);
		
		// 料金サービス識別取得
		String prcSvcSkbtCd = this.getPrcSvcSkbtCd(inMap);
		
		// 課金対象割賦サービス契約情報出力
		JBSbatOutputItem outputInItem = new JBSbatOutputItem();
		
		this.makeOutputInfo(inMap, useDayCntData, prcSvcSkbtCd, outputInItem);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][execute]");
		
		return outputInItem;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][terminal]");
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_AC_M_PRC_SVC_KANRI.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][terminal]");
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**
	 * SQLKEY(AC_SELECT_001)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	システムコード
	 *		 	群月末日
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeAC_M_PRC_SVC_KANRI_AC_SELECT_001(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());

		// DBアクセスを実行します
		db_AC_M_PRC_SVC_KANRI.selectBySqlDefine(paramList, AC_M_PRC_SVC_KANRI_AC_SELECT_001);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
	
	/**
	 * 文字を連結します
	 * @param  string 文字
	 * @return strBuf 連結した文字列
	 */
	private String makeStr(String ...string)
	{
		StringBuffer strBuf = new StringBuffer();
		for(String str:string)
		{
			if(str == null)
			{
				strBuf.append(JACStrConst.KARA_MOJI);
			}
			else
			{
				strBuf.append(str);
			}
		}
		return strBuf.toString();
	}
	
	/**
	 * 料金サービス管理を検索して、取得した値を料金サービス管理マップへ格納する。
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	private void makePrcSvcKanriMap() throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][makePrcSvcKanriMap]");

		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
	
		// システムコード
		paramList.setValue(super.systemCode);
		// 料金サービス管理適用開始年月日、料金サービス管理適用終了年月日
		paramList.setValue(this.wk_GunEnd);

		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][makePrcSvcKanriMap][paramList=" + paramList.getList().toString() + "]");

		// SQL実行
		executeAC_M_PRC_SVC_KANRI_AC_SELECT_001(paramList.getList().toArray());
		JBSbatCommonDBInterface dbMap = db_AC_M_PRC_SVC_KANRI.selectNext();
		
		this.tmpPrcSvcKanriMap = new HashMap<String, String>();
		
		// 取得出来た場合
		while(dbMap != null)
		{
			// KEY：料金コースコード ＋ 料金サービスコード
			String key = makeStr(dbMap.getString(JBSbatAC_M_PRC_SVC_KANRI.PCRS_CD), dbMap.getString(JBSbatAC_M_PRC_SVC_KANRI.PRC_SVC_CD));
			// HashMapへ設定
			this.tmpPrcSvcKanriMap.put(key, dbMap.getString(JBSbatAC_M_PRC_SVC_KANRI.PRC_SVC_SKBT_CD));
			dbMap = db_AC_M_PRC_SVC_KANRI.selectNext(); 

		}
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][makePrcSvcKanriMap]");
		return;
	}
	
	/**
	 * 料金スケジュール定義アクセス部品を使用してスケジュール情報を取得する。
	 * （請求年月・請求年月月初日・請求年月月末日・請求年月前月末日）
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	private void getSchdlInfo() throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][getSchdlInfo]");
		
		JACbatSchdlUtil schdlUtil = new JACbatSchdlUtil(commonItem);
		try
		{
			// 請求年月
			this.tmpSeikyYm 		= schdlUtil.getBillDate(super.opeDate, JACStrConst.EVENT_CD_PRC_CALC_DAY);
			// 月初日[0] 月末日[1]
			String[] ymd 			= schdlUtil.getUseStrEnd(this.tmpSeikyYm, JACStrConst.EVENT_CD_USE_STAYMD, JACStrConst.EVENT_CD_USE_ENDYMD);
			this.tmpSeikyYmStaDay 	= ymd[0];
			this.tmpSeikyYmEndDay	= ymd[1];
			// 請求年月前月末日
			this.tmpSeikyYmBfEndDay 	= JBSbatDateUtil.adjustDate(this.tmpSeikyYmStaDay, -1);
			
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getSchdlInfo][請求年月=" + this.tmpSeikyYm + "]");
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getSchdlInfo][請求年月月初日=" + this.tmpSeikyYmStaDay + "]");
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getSchdlInfo][請求年月月末日=" + this.tmpSeikyYmEndDay + "]");
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getSchdlInfo][請求年月前月末日=" + this.tmpSeikyYmBfEndDay + "]");
		}
		finally
		{
			schdlUtil.close();
		}
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][getSchdlInfo]");
		return;
	}
	
	/**
	 * 課金対象判断を行い、booleanを返却します。
	 * @param inMap　入力電文
	 * @return boolean　true：条件を満たす場合 false：条件を満たさない場合
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	private boolean isChrgTrgtJdg(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][isChrgTrgtJdg]");
		
		boolean jdgFlg = false;
		
		// 課金開始判定
		// 判定値取得
		String chrgStaymd = inMap.getString(JBSbatACIFI030.KAP_KEI_CHRG_STAYMD);		// 割賦契約課金開始年月日
		// 入力電文．割賦契約課金開始年月日 ≠ ""（空文字） かつ 割賦契約課金開始年月日（YYYYMM） ≦ 退避．請求年月 の場合
		if (!(JACBatCommon.isNull(JPCUtilCommon.trim(chrgStaymd))) 
				&& chrgStaymd.substring(0, 6).compareTo(this.tmpSeikyYm) <= 0)
		{
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][isChrgTrgtJdg][課金開始判定：対象]");
			// 割賦契約の請求期間終了判定
			// 判定値取得
			String kapSeikyEndymd = inMap.getString(JBSbatACIFI030.KAP_SEIKY_ENDYMD);		// 割賦請求終了年月日
			BigDecimal kapPayCnt = inMap.getBigDecimal(JBSbatACIFI030.KAP_PAY_ZAN_CNT);		// 割賦支払い残回数
			// 割賦支払い残回数 ≠ ０かつ（入力電文．割賦請求終了年月日 ＝ ""（空文字） または (割賦請求終了年月日（YYYYMM） ≧ 退避．請求年月）の場合
			if ( !BigDecimal.ZERO.equals(kapPayCnt) && (JACBatCommon.isNull(JPCUtilCommon.trim(kapSeikyEndymd)) || kapSeikyEndymd.substring(0, 6).compareTo(this.tmpSeikyYm) >= 0 ))
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][isChrgTrgtJdg][割賦契約の請求期間終了判定：対象]");
				jdgFlg = true;
			}
		}
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][isChrgTrgtJdg]");
		return jdgFlg;
	}
	
	/**
	 * 利用日数取得
	 * @param inMap　入力電文
	 * @return String[] [0]:利用開始日 [1]:利用終了日 [2]:利用日数
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	private String[] getUseDayCnt(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][getUseDayCnt]");
		
		String[] returnData = new String[3];
		
		// 判定値取得
		String chrgStaymd = inMap.getString(JBSbatACIFI030.KAP_KEI_CHRG_STAYMD);	// 割賦契約課金開始年月日
		String chrgEndymd = inMap.getString(JBSbatACIFI030.CHRG_ENDYMD);			// 課金終了日
		// 利用開始日取得
		{
			// 入力電文．課金終了日 ≦ 退避．請求年月前月末日 の場合
			if(chrgEndymd.compareTo(this.tmpSeikyYmBfEndDay) <= 0)
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getUseDayCnt][利用開始日取得：入力電文．課金終了日 ≦ 退避．請求年月前月末日 の場合]");
				// 退避．利用開始日 ← 入力電文．割賦契約課金開始年月日
				returnData[0] = chrgStaymd;
			}
			// 退避．請求年月月初日 ≦ 入力電文．割賦契約課金開始年月日 の場合
			else if(this.tmpSeikyYmStaDay.compareTo(chrgStaymd) <= 0)
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getUseDayCnt][利用開始日取得：退避．請求年月月初日 ≦ 入力電文．割賦契約課金開始年月日 の場合]");
				// 退避．利用開始日 ← 入力電文．割賦契約課金開始年月日
				returnData[0] = chrgStaymd;
			}
			// 退避．請求年月月初日 ＞ 入力電文．割賦契約課金開始年月日 の場合
			else if(this.tmpSeikyYmStaDay.compareTo(chrgStaymd) > 0)
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getUseDayCnt][利用開始日取得：退避．請求年月月初日 ＞ 入力電文．割賦契約課金開始年月日 の場合]");
				// 退避．利用開始日 ← 退避．請求年月月初日
				returnData[0] = this.tmpSeikyYmStaDay;
			}
			
		}
		// 利用終了日取得
		{
			// 入力電文．課金終了日 ≦ 退避．請求年月月末日 の場合
			if(chrgEndymd.compareTo(this.tmpSeikyYmEndDay) <= 0)
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getUseDayCnt][利用終了日取得：退避．請求年月月初日 ＞ 入力電文．課金開始日 の場合]");
				// 退避．利用終了日 ← 入力電文．課金終了日
				returnData[1] = chrgEndymd;
			}
			// 上記以外の場合
			else
			{
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getUseDayCnt][利用終了日取得：上記以外の場合]");
				// 退避．利用終了日 ← 退避．請求年月月末日
				returnData[1] = this.tmpSeikyYmEndDay;
			}
		}
		// 利用日数取得
		{
			// 日付共通処理部品を使用し、退避．利用開始日、退避．利用終了日から利用日数を求める。
			returnData[2] = String.valueOf(JBSbatDateUtil.dayDiff(returnData[1], returnData[0], DIFF_NAI_FLG));
		}
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][getUseDayCnt]");
		
		return returnData;
	}
	
	/**
	 * 料金サービス管理マップを検索し、料金サービス識別を取得します。
	 * @param inMap　入力電文
	 * @return String 料金サービス識別
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	private String getPrcSvcSkbtCd(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][getPrcSvcSkbtCd]");
		
		// KEY：料金コースコード ＋ 割賦プランコード
		String key = makeStr(inMap.getString(JBSbatACIFI030.PCRS_CD), 
				JACbatRknBusinessUtil.fillHalfSpace(inMap.getString(JBSbatACIFI030.KAP_PLAN_CD), PRC_SVC_CD_LEN, true));
		// 取得できなかった場合
		if(!this.tmpPrcSvcKanriMap.containsKey(key))
		{
			// ログ出力
			throw new JBSbatBusinessException(JPCBatchMessageConstant.EACB0260CH,
					new String[] {JBSbatAC_M_PRC_SVC_KANRI.TABLE_NAME, key});
		}
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][getPrcSvcSkbtCd]");
		return this.tmpPrcSvcKanriMap.get(key);
	}
	
	/**
	 * 課金対象割賦サービス契約情報を出力します。
	 * 
	 * @param inMap 入力電文
	 * @param useDayCntData 利用日数情報
	 * @param prcSvcSkbtCd 料金サービス識別
	 * @param outputInItem  出力情報
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void makeOutputInfo(JBSbatServiceInterfaceMap inMap, String[] useDayCntData, String prcSvcSkbtCd, JBSbatOutputItem outputInItem) throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][makeOutputInfo]");
		
		JBSbatServiceInterfaceMap outMap = new JBSbatServiceInterfaceMap();
		// 入力電文コピー
		outMap.setMap(inMap.getMap());
		
		String prcSvcCdFill = JPCUtilCommon.fillHalfSpace(inMap.getString(JBSbatACIFI030.KAP_PLAN_CD), 12, true);

		// 料金サービス識別
		outMap.set(JBSbatACIFM166.SVC_SKBT_CD, 			prcSvcSkbtCd);
		// 料金サービスコード
		outMap.set(JBSbatACIFM166.PRC_SVC_CD, 			prcSvcCdFill);
		// オプションサービス契約番号
		outMap.set(JBSbatACIFM166.OP_SVC_KEI_NO, 		JACStrConst.KARA_MOJI);
		// 割引サービス契約番号
		outMap.set(JBSbatACIFM166.WRIB_SVC_KEI_NO, 		JACStrConst.KARA_MOJI);
		// 割引サービス対象契約番号
		outMap.set(JBSbatACIFM166.WRISVC_TRGT_KEI_NO, 	JACStrConst.KARA_MOJI);
		// 請求年月
		outMap.set(JBSbatACIFM166.SEIKY_YM, 			this.tmpSeikyYm);
		// サービス回復日
		outMap.set(JBSbatACIFM166.SVC_KAIHK_DAY, 		JACStrConst.KARA_MOJI);
		// 利用開始日
		outMap.set(JBSbatACIFM166.USE_STAYMD, 			useDayCntData[0]);
		// 利用終了日
		outMap.set(JBSbatACIFM166.USE_ENDYMD, 			useDayCntData[1]);
		// 利用日数
		outMap.set(JBSbatACIFM166.USE_DAY_CNT, 			useDayCntData[2]);
		// 利用不可日数
		outMap.set(JBSbatACIFM166.USE_FAIL_DAY_CNT, 	BigDecimal.ZERO);
		// 相対区分
		outMap.set(JBSbatACIFM166.AIT_DIV, 				JACStrConst.AITAIKBN_NON);
		// 締め日
		outMap.set(JBSbatACIFM166.SIME_DAY, 			JACStrConst.SIME_DAY_GETUMATSU);
		// 課金開始日
		outMap.set(JBSbatACIFM166.CHRG_STAYMD, 			inMap.getString(JBSbatACIFI030.KAP_KEI_CHRG_STAYMD));
		// 初回課金開始日
		outMap.set(JBSbatACIFM166.FIRST_CHRG_STAYMD, 	inMap.getString(JBSbatACIFI030.KAP_KEI_CHRG_STAYMD));
		
		// 出力フラグ設定
		outMap.setOutFlg(true);
		
		outputInItem.addOutMapList(outMap);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][makeOutputInfo]");

		return;
	}
}
