/*********************************************************************
 *	All Rights reserved,Copyright (c) K-Opticom
 **********************************************************************
 *＜プログラム内容＞
 *   システム名      ：eo顧客基幹システム
 *   モジュール名    ：JCHPrcTeiseiIcrnCC
 *   ソースファイル名：JCHPrcTeiseiIcrnCC.java
 *   作成者          ：富士通
 *   日付            ：2011年11月17日
 *＜機能概要＞
 *   料金訂正一覧取得CC部品です。
 *＜修正履歴＞
 *	バージョン	修正日		修正者		修正内容
 *	v1.00.00	2011/11/17	富士通		新規作成
 *
 **********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;

import com.fujitsu.futurity.bp.x21.bpm.ServiceComponentRequestInvoker;
import com.fujitsu.futurity.bp.x21.bpm.db.SessionHandle;
import com.fujitsu.futurity.bp.x21.bpm.exception.RequestParameterException;
import com.fujitsu.futurity.bp.x21.bpm.parameter.IRequestParameterReadWrite;
import com.fujitsu.futurity.bp.x21.cc.AbstractCommonComponent;
import com.fujitsu.futurity.common.JCMConstants;
import com.fujitsu.futurity.common.x01.sc.SCControlMapKeys;
import com.fujitsu.futurity.mapping.bp.common.TemplateErrorUtil;
import com.fujitsu.futurity.model.base.CAANMsg;
import com.fujitsu.futurity.model.common.JCMAPLConstMgr;

import eo.common.constant.JACStrConst;
import eo.common.constant.JPCModelConstant;
import eo.common.util.JCCToolTextDecimalFormat;
import eo.common.util.JCRUtilCommon;
import eo.ejb.cbs.cbsmsg.ECH0011B011CBSMsg;
import eo.ejb.cbs.cbsmsg.ECH0011B011CBSMsg1List;

/**
 * 請求収納の各サービスより呼び出される料金訂正一覧取得CC部品です。
 * <p>
 * <BR>
 * 
 * @author 富士通
 */
public class JCHPrcTeiseiIcrnCC extends AbstractCommonComponent
{

	/** マップID */
	private static final String MAP_CC_ID = "PRCTEISEIICRNSTKUCC";

	/** テンプレートID(料金訂正一覧照会) */
	private static final String TEMPLATE_ID_ECH0011B011 = "ECH0011B011";

	/** 料金訂正一覧取得マップキー(ＫＥＹ＿請求契約番号) */
	private static final String MAP_KEY_KEY_SEIKY_KEI_NO = "key_seiky_kei_no";

	/** 料金訂正一覧取得マップキー(ＫＥＹ＿請求年月) */
	private static final String MAP_KEY_KEY_SEIKY_YM = "key_seiky_ym";

	/** 料金訂正一覧取得マップキー(ＫＥＹ＿訂正区分) */
	private static final String MAP_KEY_KEY_TEISEI_DIV = "key_teise_div";

	/** 料金訂正一覧取得マップキー(ＫＥＹ＿料金訂正日（ｆｒｏｍ）) */
	private static final String MAP_KEY_KEY_PRC_TEISE_YMD_FROM = "key_prc_teise_ymd_from";

	/** 料金訂正一覧取得マップキー(ＫＥＹ＿料金訂正日（ｔｏ）) */
	private static final String MAP_KEY_KEY_PRC_TEISE_YMD_TO = "key_prc_teise_ymd_to";

	/** 料金訂正一覧取得マップキー(ＫＥＹ＿操作者) */
	private static final String MAP_KEY_KEY_OPEACNT = "key_opeacnt";

	/** 料金訂正一覧取得マップキー(ＫＥＹ＿登録区分) */
	private static final String MAP_KEY_KEY_ADD_DIV = "key_add_div";

	/** 料金訂正一覧取得マップキー(ＫＥＹ＿補償費扱い) */
	private static final String MAP_KEY_KEY_HSHIAK_PRC_TEISEI = "key_hshiak_prc_teisei";

	/** 料金訂正一覧取得マップキー(料金対応記録一覧明細) */
	private static final String MAP_KEY_PRC_TTEISEI_LIST = "ECH0011B011CBSMsg1List";

	/** 料金訂正一覧取得マップキー(料金対応ユーザID名称) */
	private static final String MAP_KEY_PRC_TAIO_USER_ID_NM = "oprt_nm";

	/** 料金訂正一覧取得マップキー(料金対応記録年月日時分秒) */
	private static final String MAP_KEY_PRC_TAIO_KIROK_DTM = "prc_taio_kirok_dtm";

	/** 料金訂正一覧取得マップキー(料金対応記録種別コード名称) */
	private static final String MAP_KEY_PRC_TAIO_KIROK_SBT_CD_NM = "prc_taio_kirok_sbt_cd_nm";

	/** 料金訂正一覧取得マップキー(料金対応記録種別詳細コード名称) */
	private static final String MAP_KEY_PRC_TAIO_KIROK_SBT_DTL_CD_NM = "prc_taio_kirok_sbt_dtl_cd_nm";

	/** 料金訂正一覧取得マップキー(記事) */
	private static final String MAP_KEY_KIJI = "kiji";

	/** 料金訂正一覧取得マップキー(履歴情報) */
	private static final String MAP_KEY_RIREKI_INFO = "rireki_info";

	/** 料金訂正一覧取得マップキー(請求年月) */
	private static final String MAP_KEY_SEIKY_YM = "seiky_ym";

	/** 料金訂正一覧取得マップキー(請求契約番号) */
	private static final String MAP_KEY_SEIKY_KEI_NO = "seiky_kei_no";

	/** 料金訂正一覧取得マップキー(登録区分名称) */
	private static final String MAP_KEY_ADD_DIV_NM = "add_div_nm";

	/** 料金訂正一覧取得マップキー(補償費扱い料金訂正有無名称) */
	private static final String MAP_KEY_HSHIAL_PRC_TEISE_UM_NM = "hshiak_prc_teise_um_nm";

	/** 料金訂正一覧取得マップキー(送付先名) */
	private static final String MAP_KEY_SOHUS_NM = "sohus_nm";

	/** 料金訂正一覧取得マップキー(電子ファイル管理番号) */
	private static final String MAP_KEY_EFILE_KANRI_NO = "output_efile_kanri_no";

	/** 項目変更パターン値(変更前：NULL／変更後：NULL) */
	private static final String PTN_0_0 = "00";
	/** 項目変更パターン値(変更前：NULL／変更後：NOT NULL) */
	private static final String PTN_0_1 = "01";
	/** 項目変更パターン値(変更前：NOT NULL／変更後：NULL) */
	private static final String PTN_1_0 = "10";
	/** 項目変更パターン値(変更前：NOT NULL、変更後：NOT NULL) */
	private static final String PTN_1_1 = "11";

	/** 項目パターン値(NOT NULL) */
	private static final String PTN_1 = "1";

	/**
	 * 料金訂正一覧取得処理.<br>
	 * 料金訂正一覧取得マップに指定されたキー情報を基に料金対応記録一覧を取得します。 <br>
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText サービスメッセージ
	 * @return リクエストパラメータ
	 * @throws Exception 例外が発生した場合
	 */
	public IRequestParameterReadWrite getInfo(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Exception
	{
		/* ◇料金訂正一覧照会サービスインターフェイス */
		execECH0011B011(handle, param);

		return param;
	}

	/**
	 * 料金訂正一覧取得処理チェック処理.<br>
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText サービスメッセージ
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException RequestParameterException
	 */
	public HashMap<String, Object> getInvokeCBS(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws RequestParameterException
	{
		/* ◇パラメータマップ生成 */
		HashMap<String, Object> paramMap = this.createNewParamMap(param);

		/* ◇テンプレートリスト生成 */
		ArrayList<CAANMsg> templateList = new ArrayList<CAANMsg>();

		// 料金訂正一覧照会サービスIF用メッセージ設定処理
		ArrayList<CAANMsg> templateECH0011B011 = editInMsgECH0011B011(param);

		for (CAANMsg msg : templateECH0011B011)
		{
			templateList.add(msg);
		}

		CAANMsg[] templates = templateList.toArray(new CAANMsg[templateList.size()]);
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}

	// ▼▼ サービスIF呼び出し ▼▼
	/**
	 * 料金訂正一覧照会サービスインタフェイスを実行します。 <br>
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @throws Exception 例外が発生した場合
	 */
	private void execECH0011B011(SessionHandle handle, IRequestParameterReadWrite param) throws Exception
	{
		/* ◇パラメータマップ生成 */
		HashMap<String, Object> paramMap = this.createNewParamMap(param);

		/* ◇テンプレートリスト生成 */
		ArrayList<CAANMsg> templateList = new ArrayList<CAANMsg>();

		// 上りマッピング
		ArrayList<CAANMsg> templateECH0011B011 = editInMsgECH0011B011(param);
		for (CAANMsg msg : templateECH0011B011)
		{
			templateList.add(msg);
		}
		CAANMsg[] templates = templateList.toArray(new CAANMsg[templateList.size()]);
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		// ＳＣ呼出実行
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		Map<?, ?> result = scCall.run(paramMap, handle);

		// 下りマッピング
		editOutMsgECH0011B011(result, param);
	}

	// ▲▲ サービスIF呼び出し ▲▲

	// ▼▼ サービスIF用メッセージ設定処理 ▼▼
	/**
	 * 料金訂正一覧照会サービスインターフェイス用メッセージ設定処理<br>
	 * 
	 * @param param リクエストパラメータ
	 * @return ArrayList<CAANMsg>
	 * @throws RequestParameterException
	 */
	private ArrayList<CAANMsg> editInMsgECH0011B011(IRequestParameterReadWrite param) throws RequestParameterException
	{
		HashMap<String, Object> inMap = getMap(param);
		ArrayList<CAANMsg> templateList = new ArrayList<CAANMsg>();

		/* ◇ユーザデータ情報 */
		CAANMsg template = new CAANMsg(ECH0011B011CBSMsg.class.getName());
		this.setTemplateCommonItem(param, template, ECH0011B011CBSMsg.TEMPLATEID, TEMPLATE_ID_ECH0011B011, ECH0011B011CBSMsg.FUNC_CODE);

		/* ◇業務データの設定 */
		// 機能コード
		template.set(ECH0011B011CBSMsg.FUNC_CODE, JPCModelConstant.FUNC_CD_1);

		// 最大検索件数
		if (JCRUtilCommon.isNull(inMap.get("max_search_num")))
		{
			template.setNull(ECH0011B011CBSMsg.MAX_SEARCH_NUM);
		}
		else
		{
			template.set(ECH0011B011CBSMsg.MAX_SEARCH_NUM, (String)inMap.get("max_search_num"));
		}

		// 表示件数
		if (JCRUtilCommon.isNull(inMap.get("display_num")))
		{
			template.setNull(ECH0011B011CBSMsg.DISPLAY_NUM);
		}
		else
		{
			template.set(ECH0011B011CBSMsg.DISPLAY_NUM, (String)inMap.get("display_num"));
		}

		// 表示ページ番号
		if (JCRUtilCommon.isNull(inMap.get("display_page_num")))
		{
			template.setNull(ECH0011B011CBSMsg.DISPLAY_PAGE_NUM);
		}
		else
		{
			template.set(ECH0011B011CBSMsg.DISPLAY_PAGE_NUM, (String)inMap.get("display_page_num"));
		}

		// 料金訂正一覧取得マップ.ＫＥＹ＿請求契約番号 → ＫＥＹ＿請求契約番号
		if (null == inMap || null == inMap.get(MAP_KEY_KEY_SEIKY_KEI_NO) || "".equals(inMap.get(MAP_KEY_KEY_SEIKY_KEI_NO)))
		{
			template.setNull(ECH0011B011CBSMsg.KEY_SEIKY_KEI_NO);
		}
		else
		{
			template.set(ECH0011B011CBSMsg.KEY_SEIKY_KEI_NO, (String) inMap.get(MAP_KEY_KEY_SEIKY_KEI_NO));
		}

		// 料金訂正一覧取得マップ.ＫＥＹ＿請求年月 → ＫＥＹ＿請求年月
		if (null == inMap || null == inMap.get(MAP_KEY_KEY_SEIKY_YM) || "".equals(inMap.get(MAP_KEY_KEY_SEIKY_YM)))
		{
			template.setNull(ECH0011B011CBSMsg.KEY_SEIKY_YM);
		}
		else
		{
			template.set(ECH0011B011CBSMsg.KEY_SEIKY_YM, (String) inMap.get(MAP_KEY_KEY_SEIKY_YM));
		}

		// 料金訂正一覧取得マップ.ＫＥＹ＿訂正区分 → ＫＥＹ＿訂正区分
		if (null == inMap || null == inMap.get(MAP_KEY_KEY_TEISEI_DIV) || "".equals(inMap.get(MAP_KEY_KEY_TEISEI_DIV)))
		{
			template.setNull(ECH0011B011CBSMsg.KEY_TEISE_DIV);
		}
		else
		{
			template.set(ECH0011B011CBSMsg.KEY_TEISE_DIV, (String) inMap.get(MAP_KEY_KEY_TEISEI_DIV));
		}

		// 料金訂正一覧取得マップ.ＫＥＹ＿料金訂正日（ｆｒｏｍ） → ＫＥＹ＿料金訂正日（ｆｒｏｍ）
		if (null == inMap || null == inMap.get(MAP_KEY_KEY_PRC_TEISE_YMD_FROM) || "".equals(inMap.get(MAP_KEY_KEY_PRC_TEISE_YMD_FROM)))
		{
			template.setNull(ECH0011B011CBSMsg.KEY_PRC_TEISE_YMD_FROM);
		}
		else
		{
			template.set(ECH0011B011CBSMsg.KEY_PRC_TEISE_YMD_FROM, (String) inMap.get(MAP_KEY_KEY_PRC_TEISE_YMD_FROM));
		}

		// 料金訂正一覧取得マップ.ＫＥＹ＿料金訂正日（Ｔｏ） → ＫＥＹ＿料金訂正日（Ｔｏ）
		if (null == inMap || null == inMap.get(MAP_KEY_KEY_PRC_TEISE_YMD_TO) || "".equals(inMap.get(MAP_KEY_KEY_PRC_TEISE_YMD_TO)))
		{
			template.setNull(ECH0011B011CBSMsg.KEY_PRC_TEISE_YMD_TO);
		}
		else
		{
			template.set(ECH0011B011CBSMsg.KEY_PRC_TEISE_YMD_TO, (String) inMap.get(MAP_KEY_KEY_PRC_TEISE_YMD_TO));
		}

		// 料金訂正一覧取得マップ.ＫＥＹ＿操作者 → ＫＥＹ＿操作者
		if (inMap == null || inMap.get(MAP_KEY_KEY_OPEACNT) == null || "".equals(inMap.get(MAP_KEY_KEY_OPEACNT)))
		{
			template.setNull(ECH0011B011CBSMsg.KEY_OPEACNT);
		}
		else
		{
			template.set(ECH0011B011CBSMsg.KEY_OPEACNT, (String) inMap.get(MAP_KEY_KEY_OPEACNT));
		}

		// 料金訂正一覧取得マップ.ＫＥＹ＿登録区分 → ＫＥＹ＿登録区分
		if (inMap == null || inMap.get(MAP_KEY_KEY_ADD_DIV) == null || "".equals(inMap.get(MAP_KEY_KEY_ADD_DIV)))
		{
			template.setNull(ECH0011B011CBSMsg.KEY_ADD_DIV);
		}
		else
		{
			template.set(ECH0011B011CBSMsg.KEY_ADD_DIV, (String) inMap.get(MAP_KEY_KEY_ADD_DIV));
		}

		// 料金訂正一覧取得マップ.ＫＥＹ＿補償費扱い → ＫＥＹ＿補償費扱い
		if (inMap == null || inMap.get(MAP_KEY_KEY_HSHIAK_PRC_TEISEI) == null || "".equals(inMap.get(MAP_KEY_KEY_HSHIAK_PRC_TEISEI)))
		{
			template.setNull(ECH0011B011CBSMsg.KEY_HSHIAK_PRC_TEISEI);
		}
		else
		{
			template.set(ECH0011B011CBSMsg.KEY_HSHIAK_PRC_TEISEI, (String) inMap.get(MAP_KEY_KEY_HSHIAK_PRC_TEISEI));
		}

		templateList.add(template);

		return templateList;
	}

	// ▲▲ サービスIF用メッセージ設定処理 ▲▲

	// ▼▼ サービスIF用メッセージ取得処理 ▼▼
	/**
	 * 料金訂正一覧照会サービスインターフェイス用メッセージ取得処理<br>
	 * 
	 * @param msgList メッセージリスト
	 * @param param リクエストパラメータ
	 * @return IRequestParameterReadWrite
	 * @throws Exception
	 */
	private IRequestParameterReadWrite editOutMsgECH0011B011(Map<?, ?> msgList, IRequestParameterReadWrite param) throws Exception
	{

		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[]) msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg parentTemplate = templates[0];
		CAANMsg[] templateArray = null;

		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);

		// 業務データ設定
		HashMap<String, Object> dataMap = getMap(param);
		if (dataMap == null)
		{
			dataMap = new HashMap<String, Object>();
			param.setData(MAP_CC_ID, dataMap);
		}

		dataMap.put("total_search_num", parentTemplate.getString("total_search_num"));
		dataMap.put("total_page_num", parentTemplate.getString("total_page_num"));
		dataMap.put("search_type", parentTemplate.getString("search_type"));

		dataMap.put("search_err_flg", parentTemplate.getString("search_err_flg"));

		templateArray = parentTemplate.getCAANMsgList(ECH0011B011CBSMsg.ECH0011B011CBSMSG1LIST);
		ArrayList<HashMap<String, Object>> dataList = (ArrayList<HashMap<String, Object>>) dataMap.get(MAP_KEY_PRC_TTEISEI_LIST);
		if (dataList == null)
		{
			dataList = new ArrayList<HashMap<String, Object>>();
		}

		if (templateArray != null)
		{
			for (int i = 0; i < templateArray.length; i++)
			{
				CAANMsg childTemplate = templateArray[i];
				if (i >= dataList.size())
				{
					dataList.add(new HashMap<String, Object>());
				}
				HashMap<String, Object> childMap = dataList.get(i);

				// 料金訂正一覧取得マップ.料金対応ユーザID名称 ← 料金訂正一覧明細.料金対応ユーザID名称
				if (childTemplate.isNull(ECH0011B011CBSMsg1List.PRC_TAIO_USER_ID_NM))
				{
					childMap.put(MAP_KEY_PRC_TAIO_USER_ID_NM, new String());
				}
				else
				{
					childMap.put(MAP_KEY_PRC_TAIO_USER_ID_NM, childTemplate.getString(ECH0011B011CBSMsg1List.PRC_TAIO_USER_ID_NM));
				}

				// 料金訂正一覧取得マップ.料金対応記録年月日時分秒 ← 料金訂正一覧明細.料金対応記録年月日時分秒
				if (childTemplate.isNull(ECH0011B011CBSMsg1List.PRC_TAIO_KIROK_DTM))
				{
					childMap.put(MAP_KEY_PRC_TAIO_KIROK_DTM, new String());
				}
				else
				{
					childMap.put(MAP_KEY_PRC_TAIO_KIROK_DTM, childTemplate.getString(ECH0011B011CBSMsg1List.PRC_TAIO_KIROK_DTM));
				}

				// 料金訂正一覧取得マップ.料金対応記録種別コード名称 ← 料金訂正一覧明細.料金対応記録種別コード名称
				if (childTemplate.isNull(ECH0011B011CBSMsg1List.PRC_TAIO_KIROK_SBT_CD_NM))
				{
					childMap.put(MAP_KEY_PRC_TAIO_KIROK_SBT_CD_NM, new String());
				}
				else
				{
					childMap.put(MAP_KEY_PRC_TAIO_KIROK_SBT_CD_NM, childTemplate.getString(ECH0011B011CBSMsg1List.PRC_TAIO_KIROK_SBT_CD_NM));
				}

				// 料金訂正一覧取得マップ.料金対応記録種別詳細コード名称 ← 料金訂正一覧明細.料金対応記録種別詳細コード名称
				if (childTemplate.isNull(ECH0011B011CBSMsg1List.PRC_TAIO_KIROK_SBT_DTL_CD_NM))
				{
					childMap.put(MAP_KEY_PRC_TAIO_KIROK_SBT_DTL_CD_NM, new String());
				}
				else
				{
					childMap.put(MAP_KEY_PRC_TAIO_KIROK_SBT_DTL_CD_NM, childTemplate.getString(ECH0011B011CBSMsg1List.PRC_TAIO_KIROK_SBT_DTL_CD_NM));
				}

				// 料金訂正一覧取得マップ.記事 ← 料金訂正一覧明細.記事
				if (childTemplate.isNull(ECH0011B011CBSMsg1List.KIJI))
				{
					childMap.put(MAP_KEY_KIJI, new String());
				}
				else
				{
					childMap.put(MAP_KEY_KIJI, childTemplate.getString(ECH0011B011CBSMsg1List.KIJI));
				}

				// 料金訂正一覧取得マップ.記録対象年月 ← 料金訂正一覧明細.記録対象年月
				if (childTemplate.isNull(ECH0011B011CBSMsg1List.SEIKY_YM))
				{
					childMap.put(MAP_KEY_SEIKY_YM, new String());
				}
				else
				{
					childMap.put(MAP_KEY_SEIKY_YM, childTemplate.getString(ECH0011B011CBSMsg1List.SEIKY_YM));
				}

				// 料金訂正一覧取得マップ.請求契約番号 ← 料金訂正一覧明細.請求契約番号
				if (childTemplate.isNull(ECH0011B011CBSMsg1List.SEIKY_KEI_NO))
				{
					childMap.put(MAP_KEY_SEIKY_KEI_NO, new String());
				}
				else
				{
					childMap.put(MAP_KEY_SEIKY_KEI_NO, childTemplate.getString(ECH0011B011CBSMsg1List.SEIKY_KEI_NO));
				}

				// 料金訂正一覧取得マップ.補償費扱い料金訂正有無名称 ← 料金訂正一覧明細.補償費扱い料金訂正有無名称
				if (childTemplate.isNull(ECH0011B011CBSMsg1List.HSHIAK_PRC_TEISE_UM_NM))
				{
					childMap.put(MAP_KEY_HSHIAL_PRC_TEISE_UM_NM, new String());
				}
				else
				{
					childMap.put(MAP_KEY_HSHIAL_PRC_TEISE_UM_NM, childTemplate.getString(ECH0011B011CBSMsg1List.HSHIAK_PRC_TEISE_UM_NM));
				}

				// 料金訂正一覧取得マップ.補償費扱い料金訂正有無名称 ← 料金訂正一覧明細.補償費扱い料金訂正有無名称
				if (childTemplate.isNull(ECH0011B011CBSMsg1List.ADD_DIV_NM))
				{
					childMap.put(MAP_KEY_ADD_DIV_NM, new String());
				}
				else
				{
					childMap.put(MAP_KEY_ADD_DIV_NM, childTemplate.getString(ECH0011B011CBSMsg1List.ADD_DIV_NM));
				}

				// 料金訂正一覧取得マップ.送付先名 ← 料金訂正一覧明細.送付先名
				if (childTemplate.isNull(ECH0011B011CBSMsg1List.SOHUS_NM))
				{
					childMap.put(MAP_KEY_SOHUS_NM, new String());
				}
				else
				{
					childMap.put(MAP_KEY_SOHUS_NM, childTemplate.getString(ECH0011B011CBSMsg1List.SOHUS_NM));
				}

				// 料金訂正一覧取得マップ.電子ファイル管理番号 ← 料金訂正一覧明細.電子ファイル管理番号
				if (childTemplate.isNull(ECH0011B011CBSMsg1List.EFILE_KANRI_NO))
				{
					childMap.put(MAP_KEY_EFILE_KANRI_NO, new String());
				}
				else
				{
					childMap.put(MAP_KEY_EFILE_KANRI_NO, childTemplate.getString(ECH0011B011CBSMsg1List.EFILE_KANRI_NO));
				}

				/* ◇履歴情報の生成 */
				childMap.put(MAP_KEY_RIREKI_INFO, this.buildRirekiInfo(childTemplate));
			}
		}
		dataMap.put(MAP_KEY_PRC_TTEISEI_LIST, dataList);

		// エラー情報の設定
		editErrorInfo(param, templates, (Integer) return_code);

		//エラー情報のマップを取得
		ArrayList<Object> errList = (ArrayList<Object>) param.getControlMapData(SCControlMapKeys.ERROR_INFO);
		if (errList == null)
		{
			errList = new ArrayList<Object>();
		}
		// コントロールマップに設定
		param.setControlMapData(SCControlMapKeys.ERROR_INFO, TemplateErrorUtil.getErrorInfo(msgList, errList));

		// 例外通知
		String rtnCode = msgList.get(JCMConstants.RET_CD_INT_KEY).toString();
		String status = (String) param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		if (!("0".equals(rtnCode) && 0 == Integer.parseInt(status)))
		{
			/* TODO : 例外通知を見直し */
			throw new Exception();
			//			throw new SCCallException("INVALID_RETURN_MESSAGE", rtnCode, (Integer)return_code);
		}

		return param;
	}

	// ▲▲ サービスIF用メッセージ取得処理 ▲▲

	// ▼▼ エラー情報マッピング処理 ▼▼
	/**
	 * サービスIF実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 * 
	 * @param param リクエストパラメータ
	 * @param templates テンプレート
	 * @param returnCode リターンコード
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException RequestParameterException
	 */
	public IRequestParameterReadWrite editErrorInfo(IRequestParameterReadWrite param, CAANMsg[] templates, int returnCode) throws RequestParameterException
	{

		for (CAANMsg template : templates)
		{
			String templateId = template.getString("templateID");
			CAANMsg[] workTemplates = { template };
			if (TEMPLATE_ID_ECH0011B011.equals(templateId))
			{
				// 料金訂正一覧照会
				editErrorInfoECH0011B011(param, workTemplates, returnCode);
			}
		}

		return param;
	}

	/**
	 * 料金訂正一覧照会サービスIF実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 * 
	 * @param param リクエストパラメータ
	 * @param templates テンプレート
	 * @param returnCode リターンコード
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException RequestParameterException
	 */
	public IRequestParameterReadWrite editErrorInfoECH0011B011(IRequestParameterReadWrite param, CAANMsg[] templates, int returnCode)
			throws RequestParameterException
	{
		CAANMsg template = templates[0];

		int templateStatus = template.getInt(ECH0011B011CBSMsg.STATUS);

		if (returnCode != 0)
		{
			templateStatus = 9000;
		}

		if (JCMAPLConstMgr.getString("RETURN_MESSAGE_" + String.format("%1$04d", templateStatus)) == null)
		{
			templateStatus = 0;
		}

		int bpStatus = 0;
		Object obj = param.getControlMapData(SCControlMapKeys.RETURN_CODE);
		if (obj == null)
		{
			bpStatus = -1;
		}
		else
		{
			bpStatus = Integer.parseInt((String) param.getControlMapData(SCControlMapKeys.RETURN_CODE));
		}

		if (templateStatus > bpStatus)
		{
			// BPにサービスコンポーネントのステータスを設定する。
			String formatStatus = String.format("%1$04d", templateStatus);
			String message = JCMAPLConstMgr.getString("RETURN_MESSAGE_" + formatStatus);
			param.setControlMapData(SCControlMapKeys.RETURN_CODE, formatStatus);
			param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, message);
		}

		HashMap<String, Object> inMap = getMap(param);

		// 料金訂正一覧取得マップ.ＫＥＹ＿請求契約番号 → ＫＥＹ＿請求契約番号 のエラー情報返却
		if (!template.isNull(ECH0011B011CBSMsg.KEY_SEIKY_KEI_NO_ERR))
		{
			if (!inMap.containsKey(ECH0011B011CBSMsg.KEY_SEIKY_KEI_NO_ERR))
			{
				inMap.put(ECH0011B011CBSMsg.KEY_SEIKY_KEI_NO_ERR, template.getString(ECH0011B011CBSMsg.KEY_SEIKY_KEI_NO_ERR));
			}
		}

		return param;
	}

	// ▲▲ エラー情報マッピング処理 ▲▲

	// ▼▼ クラス内共通処理 ▼▼
	/**
	 * サービスインタフェースに渡すパラメータマップを新規に作成します。 マップには共通項目である電文ヘッダ、コントロールマップを設定します。 <br>
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @throws RequestParameterException パラメータ取得で例外が発生した場合
	 */
	private HashMap<String, Object> createNewParamMap(IRequestParameterReadWrite param) throws RequestParameterException
	{
		HashMap<String, Object> paramMap = new HashMap<String, Object>();

		/* ◇電文ヘッダ */
		// 電文ID
		paramMap.put(JCMConstants.TRANZACTION_ID_KEY, param.getTelegramID());
		// ユースケースID
		paramMap.put(JCMConstants.USECASE_ID_KEY, param.getUsecaseID());
		// オペレーションID
		paramMap.put(JCMConstants.OPERATION_ID_KEY, param.getOperationID());
		// サービス呼び出し区分
		paramMap.put(JCMConstants.CALL_TYPE_KEY, param.getCallType());

		/* ◇コントロールマップ */
		// 依頼先ホスト名
		paramMap.put(JCMConstants.CLIENT_HOST_NAME_KEY, param.getControlMapData(SCControlMapKeys.REQ_HOSTNAME));
		// 依頼元IPアドレス
		paramMap.put(JCMConstants.CLIENT_IP_ADDRESS_KEY, param.getControlMapData(SCControlMapKeys.REQ_HOSTIP));
		// 依頼元画面ID
		paramMap.put(JCMConstants.INVOKE_GAMEN_ID_KEY, param.getControlMapData(SCControlMapKeys.REQ_VIEWID));
		// オペレータID
		paramMap.put(JCMConstants.OPERATOR_ID_KEY, param.getControlMapData(SCControlMapKeys.OPERATOR_ID));

		return paramMap;
	}

	/**
	 * テンプレートの共通項目を設定します。 <br>
	 * 
	 * @param param リクエストパラメータ
	 * @param template テンプレート
	 * @param templateIdKey テンプレートIDキー名
	 * @param templateIdVal テンプレートID値
	 * @param templateFuncCdKey テンプレート機能コードキー名
	 * @throws RequestParameterException パラメータ取得で例外が発生した場合
	 */
	private CAANMsg setTemplateCommonItem(IRequestParameterReadWrite param, CAANMsg template, String templateIdKey, String templateIdVal,
			String templateFuncCdKey) throws RequestParameterException
	{
		// テンプレートID
		template.set(templateIdKey, templateIdVal);

		// 機能コード（デフォルト：１）
		template.set(templateFuncCdKey, "1");

		// オペレータID
		Object operatorId = param.getControlMapData(SCControlMapKeys.OPERATOR_ID);
		template.set(JCMConstants.OPERATOR_ID_KEY, operatorId);

		// 運用日付
		Object operateDate = param.getControlMapData(SCControlMapKeys.OPE_DATE);
		template.set(JCMConstants.OPERATE_DATE_KEY, operateDate);

		// 運用日時
		Object operateDateTime = param.getControlMapData(SCControlMapKeys.OPE_TIME);
		template.set(JCMConstants.OPERATE_DATETIME_KEY, operateDateTime);

		// 検索処理パターン
		template.setNull(ECH0011B011CBSMsg.SEARCH_TYPE);

		// 最大検索件数
		template.setNull(ECH0011B011CBSMsg.MAX_SEARCH_NUM);

		// 表示件数
		template.setNull(ECH0011B011CBSMsg.DISPLAY_NUM);

		// 表示ページ番号
		template.setNull(ECH0011B011CBSMsg.DISPLAY_PAGE_NUM);
		return template;
	}

	/**
	 * 料金訂正一覧取得マップを返却します。 <br>
	 * 
	 * @param param リクエストパラメータ
	 * @param key 項目名
	 * @param value 値
	 * @throws RequestParameterException パラメータ取得で例外が発生した場合
	 */
	@SuppressWarnings("unchecked")
	private HashMap<String, Object> getMap(IRequestParameterReadWrite param) throws RequestParameterException
	{
		return (HashMap<String, Object>) param.getData(MAP_CC_ID);
	}

	// ▲▲ クラス内共通処理 ▲▲

	// ▼▼ 履歴情報生成処理 ▼▼
	/**
	 * 履歴情報生成処理<br>
	 * 料金訂正一覧照会の明細テンプレートから履歴情報を生成します。 <br>
	 * 
	 * @param childTemplate 料金訂正一覧明細テンプレート１件
	 */
	private String buildRirekiInfo(CAANMsg childTemplate)
	{
		StringBuffer rirekiInfo = new StringBuffer();

		String convertPattern = getRirekiInfoConvertPattern(childTemplate);

		String info = null;
		/* ◇金額履歴情報 */
		info = buildAmntRirekiInfo(childTemplate, convertPattern);
		rirekiInfo.append(info);

		/* ◇コード種別履歴情報 */
		info = buildCdSbtRirekiInfo(childTemplate, convertPattern);
		if (!JACStrConst.KARA_MOJI.equals(info))
		{
			if (rirekiInfo.length() > 0)
			{
				rirekiInfo.append(JACStrConst.SPACE_1);
			}
			rirekiInfo.append(info);
		}

		/* ◇料金項目履歴情報 */
		info = buildPrcKmkRirekiInfo(childTemplate, convertPattern);
		if (!JACStrConst.KARA_MOJI.equals(info))
		{
			if (rirekiInfo.length() > 0)
			{
				rirekiInfo.append(JACStrConst.SPACE_1);
			}
			rirekiInfo.append(info);
		}

		/* ◇日付履歴情報 */
		info = buildYmdRirekiInfo(childTemplate, convertPattern);
		if (!JACStrConst.KARA_MOJI.equals(info))
		{
			if (rirekiInfo.length() > 0)
			{
				rirekiInfo.append(JACStrConst.SPACE_1);
			}
			rirekiInfo.append(info);
		}

		/* ◇請求番号履歴情報 */
		info = buildSeikyNoRirekiInfo(childTemplate);
		if (!JACStrConst.KARA_MOJI.equals(info))
		{
			if (rirekiInfo.length() > 0)
			{
				rirekiInfo.append(JACStrConst.SPACE_1);
			}
			rirekiInfo.append(info);
		}
		
		return rirekiInfo.toString();
	}

	/**
	 * 履歴情報変換パターン値取得処理<br>
	 * 金額、コード種別、料金項目コードの変更前後を比較して、履歴情報の変換パターン値を取得します。 <br>
	 * 
	 * @param childTemplate 料金訂正一覧明細テンプレート１件
	 * @return 履歴情報変換パターン値
	 */
	private String getRirekiInfoConvertPattern(CAANMsg childTemplate)
	{
		StringBuffer convertPattern = new StringBuffer();

		String itemChgPattern = null;
		/* ◇金額変更パターン */
		itemChgPattern = getItemChgPattern(childTemplate, ECH0011B011CBSMsg1List.CHG_BF_AMNT, ECH0011B011CBSMsg1List.CHG_AF_AMNT);
		convertPattern.append(itemChgPattern);

		/* ◇コード種別コード変更パターン */
		itemChgPattern = getItemChgPattern(childTemplate, ECH0011B011CBSMsg1List.CHG_BF_CD_SBT_CD, ECH0011B011CBSMsg1List.CHG_AF_CD_SBT_CD);
		convertPattern.append(itemChgPattern);

		/* ◇料金項目コード変更パターン */
		itemChgPattern = getItemChgPattern(childTemplate, ECH0011B011CBSMsg1List.CHG_BF_PRC_KMK_CD, ECH0011B011CBSMsg1List.CHG_AF_PRC_KMK_CD);
		convertPattern.append(itemChgPattern);

		/* ◇日付変更パターン*/
		itemChgPattern = getItemChgPattern(childTemplate, ECH0011B011CBSMsg1List.CHG_BF_YMD, ECH0011B011CBSMsg1List.CHG_AF_YMD);
		convertPattern.append(itemChgPattern);

		return convertPattern.toString();
	}

	/**
	 * 項目変更パターン値取得処理<br>
	 * 指定された項目の変更前後の値を比較して２桁のパターン値を取得します。 <br>
	 * 
	 * @param childTemplate 料金訂正一覧明細テンプレート１件
	 * @param bfItemKey 変更前項目キー名
	 * @param afItemKey 変更後項目キー名
	 */
	private String getItemChgPattern(CAANMsg childTemplate, String bfItemKey, String afItemKey)
	{
		String chgPattern = null;
		if (childTemplate.isNull(bfItemKey) && childTemplate.isNull(afItemKey))
		{
			chgPattern = PTN_0_0;
		}
		else if (childTemplate.isNull(bfItemKey) && !childTemplate.isNull(afItemKey))
		{
			chgPattern = PTN_0_1;
		}
		else if (!childTemplate.isNull(bfItemKey) && childTemplate.isNull(afItemKey))
		{
			chgPattern = PTN_1_0;
		}
		else if (!childTemplate.isNull(bfItemKey) && !childTemplate.isNull(afItemKey))
		{
			chgPattern = PTN_1_1;
		}

		return chgPattern;
	}

	/**
	 * 金額履歴情報生成処理<br>
	 * 履歴情報変換パターンを基に料金訂正一覧照会の明細テンプレートから金額の履歴情報を生成します。 <br>
	 * 
	 * @param childTemplate 料金訂正一覧明細テンプレート１件
	 * @param convertPattern 履歴情報変換パターン
	 * @return 金額履歴情報
	 */
	private String buildAmntRirekiInfo(CAANMsg childTemplate, String convertPattern)
	{
		StringBuffer rirekiInfo = new StringBuffer();

		if (!PTN_0_0.equals(convertPattern.substring(0, 2)))
		{
			JCCToolTextDecimalFormat formatter = new JCCToolTextDecimalFormat("#,###");

			rirekiInfo.append("【金額：");
			if (PTN_1.equals(convertPattern.substring(0, 1)))
			{
				rirekiInfo.append(formatter.formattedPrint(childTemplate.getString(ECH0011B011CBSMsg1List.CHG_BF_AMNT)));
			}
			if (PTN_1_1.equals(convertPattern.substring(0, 2)))
			{
				rirekiInfo.append("→");
			}
			if (PTN_1.equals(convertPattern.substring(1, 2)))
			{
				rirekiInfo.append(formatter.formattedPrint(childTemplate.getString(ECH0011B011CBSMsg1List.CHG_AF_AMNT)));
			}
			rirekiInfo.append("】");
		}

		return rirekiInfo.toString();
	}

	/**
	 * コード種別履歴情報生成処理<br>
	 * 履歴情報変換パターンを基に料金訂正一覧照会の明細テンプレートからコード種別の履歴情報を生成します。 <br>
	 * 
	 * @param childTemplate 料金訂正一覧明細テンプレート１件
	 * @param convertPattern 履歴情報変換パターン
	 * @return コード種別履歴情報
	 */
	private String buildCdSbtRirekiInfo(CAANMsg childTemplate, String convertPattern)
	{
		StringBuffer rirekiInfo = new StringBuffer();

		if (!PTN_0_0.equals(convertPattern.substring(2, 4)))
		{
			rirekiInfo.append("【状態：");
			if (PTN_1.equals(convertPattern.substring(2, 3)))
			{
				rirekiInfo.append(childTemplate.getString(ECH0011B011CBSMsg1List.CHG_BF_CD_DIV_NM));
			}
			if (PTN_1_1.equals(convertPattern.substring(2, 4)))
			{
				rirekiInfo.append("→");
			}
			if (PTN_1.equals(convertPattern.substring(3, 4)))
			{
				rirekiInfo.append(childTemplate.getString(ECH0011B011CBSMsg1List.CHG_AF_CD_DIV_NM));
			}
			rirekiInfo.append("】");
		}

		return rirekiInfo.toString();
	}

	/**
	 * 料金項目履歴情報生成処理<br>
	 * 履歴情報変換パターンを基に料金訂正一覧照会の明細テンプレートから料金項目の履歴情報を生成します。 <br>
	 * 
	 * @param childTemplate 料金訂正一覧明細テンプレート１件
	 * @param convertPattern 履歴情報変換パターン
	 * @return 料金項目情報
	 */
	private String buildPrcKmkRirekiInfo(CAANMsg childTemplate, String convertPattern)
	{
		StringBuffer rirekiInfo = new StringBuffer();

		if (!PTN_0_0.equals(convertPattern.substring(4, 6)))
		{
			rirekiInfo.append("【状態：");
			if (PTN_1.equals(convertPattern.substring(4, 5)))
			{
				String bfPcrs = codeNameEdit(childTemplate, ECH0011B011CBSMsg1List.CHG_BF_PCRS_CD, ECH0011B011CBSMsg1List.CHG_BF_PCRS_CD_NM);
				String bfPrcSvc = codeNameEdit(childTemplate, ECH0011B011CBSMsg1List.CHG_BF_PRC_SVC_CD, ECH0011B011CBSMsg1List.CHG_BF_PRC_SVC_CD_NM);
				String bfPrcKmk = codeNameEdit(childTemplate, ECH0011B011CBSMsg1List.CHG_BF_PRC_KMK_CD, ECH0011B011CBSMsg1List.CHG_BF_PRC_KMK_CD_NM);

				rirekiInfo.append(bfPcrs);
				if (bfPcrs != null && !JACStrConst.KARA_MOJI.equals(bfPcrs))
				{
					rirekiInfo.append(JACStrConst.SPACE_1);
				}

				rirekiInfo.append(bfPrcSvc);
				if (bfPrcSvc != null && !JACStrConst.KARA_MOJI.equals(bfPrcSvc))
				{
					rirekiInfo.append(JACStrConst.SPACE_1);
				}

				rirekiInfo.append(bfPrcKmk);
			}

			if (PTN_1_1.equals(convertPattern.substring(4, 6)))
			{
				rirekiInfo.append("→");
			}

			if (PTN_1.equals(convertPattern.substring(5, 6)))
			{
				String afPcrs = codeNameEdit(childTemplate, ECH0011B011CBSMsg1List.CHG_AF_PCRS_CD, ECH0011B011CBSMsg1List.CHG_AF_PCRS_CD_NM);
				String afPrcSvc = codeNameEdit(childTemplate, ECH0011B011CBSMsg1List.CHG_AF_PRC_SVC_CD, ECH0011B011CBSMsg1List.CHG_AF_PRC_SVC_CD_NM);
				String afPrcKmk = codeNameEdit(childTemplate, ECH0011B011CBSMsg1List.CHG_AF_PRC_KMK_CD, ECH0011B011CBSMsg1List.CHG_AF_PRC_KMK_CD_NM);

				rirekiInfo.append(afPcrs);
				if (afPcrs != null && !JACStrConst.KARA_MOJI.equals(afPcrs))
				{
					rirekiInfo.append(JACStrConst.SPACE_1);
				}

				rirekiInfo.append(afPrcSvc);
				if (afPrcSvc != null && !JACStrConst.KARA_MOJI.equals(afPrcSvc))
				{
					rirekiInfo.append(JACStrConst.SPACE_1);
				}

				rirekiInfo.append(afPrcKmk);
			}
			rirekiInfo.append("】");
		}

		return rirekiInfo.toString();
	}

	/**
	 * 日付履歴情報生成処理<br>
	 * 履歴情報変換パターンを基に料金対応記録一覧照会の明細テンプレートから日付の履歴情報を生成します。
	 * <br>
	 * @param childTemplate 料金対応記録一覧明細テンプレート１件
	 * @param convertPattern 履歴情報変換パターン
	 * @return 日付履歴情報
	 */	
	private String buildYmdRirekiInfo(CAANMsg childTemplate, String convertPattern)
	{
		StringBuffer rirekiInfo = new StringBuffer();
		
		try
		{
			if (!PTN_0_0.equals(convertPattern.substring(6, 8)))
			{
				rirekiInfo.append("【状態：");
				if (PTN_1.equals(convertPattern.substring(6, 7)))
				{
					String chgBfYmd = childTemplate.getString(ECH0011B011CBSMsg1List.CHG_BF_YMD);
					rirekiInfo.append(new SimpleDateFormat("yyyy/mm/dd").format(new SimpleDateFormat("yyyymmdd").parse(chgBfYmd)));
				}
				if (PTN_1_1.equals(convertPattern.substring(6, 8)))
				{
					rirekiInfo.append("→");
				}
				if (PTN_1.equals(convertPattern.substring(7, 8)))
				{
					String chgAfYmd = childTemplate.getString(ECH0011B011CBSMsg1List.CHG_AF_YMD);
					rirekiInfo.append(new SimpleDateFormat("yyyy/mm/dd").format(new SimpleDateFormat("yyyymmdd").parse(chgAfYmd)));
				}
				rirekiInfo.append("】");
			}
		}
		catch (ParseException e)
		{
			return "";
		}
		
		return rirekiInfo.toString();
	}

	/**
	 * 請求番号履歴情報生成処理<br>
	 * 料金対応記録一覧照会の明細テンプレートから請求番号の履歴情報を生成します。
	 * <br>
	 * @param childTemplate 料金対応記録一覧明細テンプレート１件
	 * @return 請求番号履歴情報
	 */	
	private String buildSeikyNoRirekiInfo(CAANMsg childTemplate)
	{
		StringBuffer rirekiInfo = new StringBuffer();
		
		//  料金対応記録種別（随時入金登録）
		if (JACStrConst.TKRK_SBT_ZUIJI_NYUKIN_ADD.equals(childTemplate.getString(ECH0011B011CBSMsg1List.PRC_TAIO_KIROK_SBT_CD)))
		{
			if (!childTemplate.isNull(ECH0011B011CBSMsg1List.SEIKY_NO))
			{
				rirekiInfo.append("【状態：");
				rirekiInfo.append(childTemplate.getString(ECH0011B011CBSMsg1List.SEIKY_NO));
				rirekiInfo.append("】");
			}
		}
		
		return rirekiInfo.toString();
	}

	/**
	 * 指定された文字にコロンを付与します。 <br>
	 * 
	 * @param childTemplate 料金対応記録一覧明細テンプレート１件
	 * @param cdValue コード値
	 * @param nmValue 名称値
	 * @return String コード + ":" + 名称
	 */
	private String codeNameEdit(CAANMsg childTemplate, String cdValue, String nmValue)
	{
		nmValue = childTemplate.getString(nmValue);
		cdValue = childTemplate.getString(cdValue);
		String rtnValue = JACStrConst.KARA_MOJI;
		StringBuffer sb = new StringBuffer();

		// 名称値がNullの場合、空文字をセット
		if (nmValue == null || JACStrConst.KARA_MOJI.equals(nmValue.trim()))
		{
			nmValue = JACStrConst.KARA_MOJI;
		}

		// コード値がNullでない場合
		if (cdValue != null && !JACStrConst.KARA_MOJI.equals(cdValue.trim()))
		{
			rtnValue = sb.append(cdValue).append(JACStrConst.COLON).append(nmValue).toString();
		}

		return rtnValue;
	}

	// ▲▲ 履歴情報生成処理 ▲▲
}
