/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：JFUAddUsePlaceInfoCC
*   ソースファイル名：JFUAddUsePlaceInfoCC.java
*   作成者          ：富士通
*   日付            ：2011年06月14日
*＜機能概要＞
*   利用場所情報登録部品
*＜修正履歴＞
*   バージョン  修正日       修正者      修正内容
*   v1.00.00    2011/07/03   FJ）        新規作成
*	v1.01.00    2013/01/26   FJ)大塚     No313 請求契約番号を設定しない対応 No255 進捗特記事項1対応
*   v1.02.00    2013/04/23   FJ)大塚     No708 エラー情報マッピング不備対応
*   v1.03.00    2013/06/12   FJ)岡井     【内部障害】進捗登録.異動年月日時分秒にシステム日付を設定するように修正
*********************************************************************/
package com.fujitsu.futurity.bp.custom.common;

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.bp.x21.cc.exception.CCException;
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.ejb.cbs.cbsmsg.EKK1091D010CBSMsg;
import eo.ejb.cbs.cbsmsg.EKK1091D010CBSMsg1List;

//IT1-2012-0001150 不要インポート削除 2012/10/16 h.iwamoto

/**
 * 進捗登録
 * <br>
 * @author 富士通
 */
public class JFUAddShintyokuCC extends AbstractCommonComponent
{
	/** テンプレートID*/
	private static final String TEMPLATE_ID = "EKK1091D010";
	/** リターンメッセージ */
	private static final String RETURN_MESSAGE_STRING = "RETURN_MESSAGE_";
	private static final String RETURN_MESSAGE_FORMAT = "%1$04d";
	/** 作業マップ名 */
	private static final String CC_WORK_AREA_NAME = "JFUAddShintyokuCCWork";
	private static final String CC_WORK_AREA_NAME_KEISHA = "JFUAddKeishaServiceCCWork";
	private static final String CC_WORK_AREA_NAME_MSKM = "JFUAddMskmSCWork";
	private static final String CC_WORK_AREA_NAME_TV = "JFUAddSvcKeiTvCCWork";
	private static final String CC_WORK_AREA_NAME_TEL = "JFUAddSvcKeiTelCCWork";
	private static final String CC_WORK_AREA_NAME_NET = "JFUAddSvcKeiNetCCWork";
	private static final String CC_WORK_AREA_NAME_MOB = "JFUAddSvcKeiMobCCWork";
	private static final String CC_WORK_AREA_NAME_SKK= "JFUAddSkkSCWork";
	/** エラー用 */
	private static final int TMCK_ERR_STATUS = 1000;
	private static final String SC_ERROR_STRING = "サービスコンポーネントエラー";

	/**
	 *進捗登録チェック処理
	 * <br>
	 * @param handle
	 * @param param
	 * @param fixedText
	 * @return
	 */
	public HashMap<String, Object> getInvokeCBS(SessionHandle handle, IRequestParameterReadWrite param, String fixedText)
			throws RequestParameterException
	{
		ArrayList<CAANMsg> msgList = new ArrayList<CAANMsg>();
		HashMap inMap = null;
		int mapCnt = 0;

		/* ユーザデータ情報 */
		HashMap inMapChk = (HashMap)(param.getData("EKK1091D010"));
		if (inMapChk != null)
		{
			inMap = (HashMap)param.getData("EKK1091D010");
			mapCnt = ((ArrayList)inMap.get("EKK1091D010List")).size();
			for (int i = 0; i < mapCnt; i++)
			{
				// 進捗登録
				msgList.add(editInEKK1091D010(param, "EKK1091D010", i));
			}
		} else {
			return null;
		}

		int msgCnt = msgList.size();
		CAANMsg[] templates = new CAANMsg[msgCnt];
		for (int i = 0; i < msgCnt; i++)
		{
			templates[i] = msgList.get(i);
		}

		HashMap<String, Object> paramMap = setSCInputCommonData(param, new HashMap<String, Object>());
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}

	/**
	 * 進捗登録処理
	 * <br>
	 * @param handle
	 * @param param
	 * @param fixedText
	 * @return
	 */
	public IRequestParameterReadWrite addShintyoku(SessionHandle handle, IRequestParameterReadWrite param, String fixedText) throws Exception
	{
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();
		HashMap<String, Object> paramMap = setSCInputCommonData(param, new HashMap<String, Object>());
		Map<?, ?> result = null;
		CAANMsg template = null;
		HashMap inMap = null;
		int mapCnt = 0;
		String prefix = "";

		/* ユーザデータ情報 */
		HashMap inMapChk = (HashMap)(param.getData("EKK1091D010"));
		if (inMapChk != null)
		{
			inMap = (HashMap)param.getData("EKK1091D010");
			mapCnt = ((ArrayList)inMap.get("EKK1091D010List")).size();
			for (int i = 0; i < mapCnt; i++)
			{
				// 進捗登録登録
				template = editInEKK1091D010(param, "EKK1091D010", i); // 上りマッピング
				result = scCall.run(putParamMap(paramMap, template), handle); // SC呼び出し
				editRetEKK1091D010(result, param, "EKK1091D010", i); // 下りマッピング
				if (getReturnCode(param) >= TMCK_ERR_STATUS)
				{ // ステータスが単項目エラー以上であれば例外をスロー
					throw new CCException(SC_ERROR_STRING, new Exception());
				}
			}

		}

		return param;
	}

	/**
	 * SCの実行ステータスの取得処理
	 * <br>
	 * @param param
	 * @return
	 */
	private int getReturnCode(IRequestParameterReadWrite param) throws Exception
	{
		return Integer.parseInt((String)param.getControlMapData(SCControlMapKeys.RETURN_CODE));
	}

	/**
	 * 単一CAANMsgのマッピング処理
	 * <br>
	 * @param paramMap
	 * @param template
	 * @return
	 */
	private HashMap<String, Object> putParamMap(HashMap<String, Object> paramMap, CAANMsg template) throws RequestParameterException
	{
		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}

	private ArrayList getWorkMapList(IRequestParameterReadWrite param, String key) throws RequestParameterException
	{
		ArrayList dataList = new ArrayList();

		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();

		HashMap inMapTv = null;
		HashMap inMapNet = null;
		HashMap inMapTel = null;
		HashMap inMapMob = null;
		HashMap inMapMskm = null;

		/* 作業項目情報 */
		if (workMap != null)
		{
			inMapTv = (HashMap)workMap.get(CC_WORK_AREA_NAME_TV);
			inMapNet = (HashMap)workMap.get(CC_WORK_AREA_NAME_NET);
			inMapTel = (HashMap)workMap.get(CC_WORK_AREA_NAME_TEL);
			inMapMob = (HashMap)workMap.get(CC_WORK_AREA_NAME_MOB);
			inMapMskm = (HashMap)workMap.get(CC_WORK_AREA_NAME_MSKM);
		}
		else
		{
			inMapTv = null;
			inMapNet = null;
			inMapTel = null;
			inMapMob = null;
			inMapMskm = null;
			dataList = null;
		}
		
		// -----進捗改修対応 2012/07/07 h.iwamoto START-----
		
		// ※申込明細番号とサービス契約番号は同順でリストを持つ必要がある為、今後改修する際は注意すること！
		
		// 申込明細番号呼出時
		if ("mskm_dtl_no".equals(key))
		{
			if (inMapTv != null)
			{
				// TV用申込明細番号
				dataList.add(inMapMskm.get("ekk0101_mskm_dtl_no"));
			}
			// NET用ワークのキーをセット
			if (inMapNet != null)
			{
				// NET用申込明細番号
				dataList.add(inMapMskm.get("ekk0091_mskm_dtl_no"));
			}
			// TEL用ワークのキーをセット
			if (inMapTel != null)
			{
				// TEL用申込明細番号
				dataList.add(inMapMskm.get("ekk0111_mskm_dtl_no"));
			}
			// モバイル用ワークのキーをセット
			if (inMapMob != null)
			{
				// モバイル用申込明細番号
				dataList.add(inMapMskm.get("ekk0121_mskm_dtl_no"));
			}

		}
		// サービス契約番号呼出時
		else
		{
			// TV用ワークのキーをセット
			if (inMapTv != null)
			{
				dataList.add((String)inMapTv.get(key));
			}
			// NET用ワークのキーをセット
			if (inMapNet != null)
			{
				dataList.add((String)inMapNet.get(key));
			}
			// TEL用ワークのキーをセット
			if (inMapTel != null)
			{
				dataList.add((String)inMapTel.get(key));
			}
			// モバイル用ワークのキーをセット
			if (inMapMob != null)
			{
				dataList.add((String)inMapMob.get(key));
			}
		}
		// -----進捗改修対応 2012/07/07 h.iwamoto START-----
		
		return dataList;
	}

	/**
	 * 請求契約情報作業エリア
	 */
	private String getSkkWorkMapValue(IRequestParameterReadWrite param, String key) throws RequestParameterException
	{
		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();

		HashMap inMap = null;
		/* 申込作業項目情報 */
		if (workMap != null)
		{
			inMap = (HashMap)workMap.get(CC_WORK_AREA_NAME_SKK);
		}
		else
		{
			inMap = null;
		}

		String result = null;
		if (inMap != null)
		{
			result = (String)inMap.get(key);
		}

		if ("".equals(result))
		{
			result = null;
		}

		return result;
	}

	/**
	 * SCインプット共通データ設定処理
	 * <br>
	 * @param param
	 * @param paramMap
	 * @return
	 */
	private HashMap<String, Object> setSCInputCommonData(IRequestParameterReadWrite param, HashMap<String, Object> paramMap)
			throws RequestParameterException
	{
		/* SCインプット共通データ */
		// **********************************************
		// 【取得元：電文ヘッダ(ヘッダ)】
		// **********************************************
		// 電文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;
	}

	/**
	 *<DL>
	 *<DT>進捗登録上りマッピング:
	 *<DD>サービスコンポーネント実行前に、CAANMsgに必要なデータをマッピングする
	 *<DT>入力パラメータ説明:
	 *<DD>特になし
	 *<DT>入力パラメータ説明：
	 *<DD>特になし
	 *<DT>出力パラメータ説明:
	 *<DD>特になし
	 *</DL>
	 * @param param (I) 業務データ取得用I/F
	 * @return サービスコンポーネント実行用CAANMsg
	 * @since 2011.07.14
	 */
	@SuppressWarnings("unchecked")
	private CAANMsg editInEKK1091D010(IRequestParameterReadWrite param, String fixedText, int index) throws RequestParameterException
	{
		HashMap<String, Object> paramMap = new HashMap<String, Object>();

		CAANMsg template = new CAANMsg(EKK1091D010CBSMsg.class.getName());
		CAANMsg[] templateArray = null;

		HashMap inMap = null;
		ArrayList inList = null;
		ArrayList svc_kei_no = null;
		ArrayList mskm_dtl_no = null;		// -----進捗対応 2012/07/07 h.iwamoto-----
		int svcCnt = 0;

		// テンプレートID
		template.set(EKK1091D010CBSMsg.TEMPLATEID, fixedText);

		// 機能コード（デフォルト：１）
		template.set(EKK1091D010CBSMsg.FUNC_CODE, "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);

		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();

		/* ユーザデータ情報 */
		inMap = (HashMap)param.getData(fixedText);

		/* ++++++++++++++++ v1.00.00 追加開始 +++++++++++++++++++++ */
		inMap = (HashMap)((ArrayList)inMap.get("EKK1091D010List")).get(index);
		/* ++++++++++++++++ v1.00.00 追加終了 +++++++++++++++++++++ */

		// 機能コード
		template.set(EKK1091D010CBSMsg.FUNC_CODE, inMap.get(JCMConstants.FUNC_CODE_KEY));

		// -----進捗改修対応 2012/07/07 h.iwamoto START-----
		// 進捗登録マップ.申込明細番号 → 申込明細番号
		if (inMap == null || inMap.get("mskm_dtl_no") == null || "".equals(inMap.get("mskm_dtl_no")))
		{
			// サービス契約数取得
			mskm_dtl_no = (ArrayList)getWorkMapList(param, "mskm_dtl_no");
			if (mskm_dtl_no != null)
			{
				svcCnt = mskm_dtl_no.size();
				if (templateArray == null)
				{
					templateArray = new CAANMsg[svcCnt];
				}
			}
			if ( svcCnt > 0 )
			{
				for (int i = 0; i < svcCnt; i++)
				{	
					if(index == i)
					{
						template.set(EKK1091D010CBSMsg.MSKM_DTL_NO, mskm_dtl_no.get(i));
					}
				}
			}
		}
		else
		{
			template.set(EKK1091D010CBSMsg.MSKM_DTL_NO, (String)inMap.get("mskm_dtl_no"));
		}
		// -----進捗改修対応 2012/07/07 h.iwamoto END-----

		// 進捗登録マップ.請求契約番号 → 請求契約番号
		// No313 2013/01/26 Otsuka 進捗の請求契約番号は設定しない
		template.setNull(EKK1091D010CBSMsg.SEIKY_KEI_NO);
//		if (inMap == null || inMap.get("seiky_kei_no") == null ||"".equals(inMap.get("seiky_kei_no")))
//		{
//			// ++++++++++++++++++++ v1.00.00 追加開始 +++++++++++++++++++++++++++++++ */
//			// template.setNull(EKK1091D010CBSMsg.SEIKY_KEI_NO);
//			if (getSkkWorkMapValue(param, "seiky_kei_no") == null)
//			{
//				template.setNull(EKK1091D010CBSMsg.SEIKY_KEI_NO);
//			}
//			else
//			{
//				template.set(EKK1091D010CBSMsg.SEIKY_KEI_NO, getSkkWorkMapValue(param, "seiky_kei_no"));
//			}
//			// +++++++++++++++++++ v1.00.00 追加終了 ++++++++++++++++++++++++++++++++ */
//		}
//		else
//		{
//			template.set(EKK1091D010CBSMsg.SEIKY_KEI_NO, (String)inMap.get("seiky_kei_no"));
//		}

		// 進捗登録マップ.請求方法番号（口座） → 請求方法番号(口座)
		if ("".equals(inMap.get("seiky_way_no_koza")))
		{
			template.setNull(EKK1091D010CBSMsg.SEIKY_WAY_NO_KOZA);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.SEIKY_WAY_NO_KOZA, (String)inMap.get("seiky_way_no_koza"));
		}

		// 進捗登録マップ.請求方法番号（クレジットカード） → 請求方法番号(クレジットカード)
		if ("".equals(inMap.get("seiky_way_no_crecard")))
		{
			template.setNull(EKK1091D010CBSMsg.SEIKY_WAY_NO_CRECARD);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.SEIKY_WAY_NO_CRECARD, (String)inMap.get("seiky_way_no_crecard"));
		}

		// 進捗登録マップ.サービス契約番号 → サービス契約番号
		if (inMap == null || inMap.get("svc_kei_no") == null || "".equals(inMap.get("svc_kei_no")))
		{
			// ++++++++++++++++++++ v1.00.00 追加開始 +++++++++++++++++++++++++++++++ */
			//template.setNull(EKK1091D010CBSMsg.SVC_KEI_NO);
			// サービス契約数取得
			svc_kei_no = (ArrayList)getWorkMapList(param, "svc_kei_no");
			if (svc_kei_no != null)
			{
				svcCnt = svc_kei_no.size();
				if (templateArray == null)
				{
					templateArray = new CAANMsg[svcCnt];
				}
			}
			if ( svcCnt > 0 )
			{
				for (int i = 0; i < svcCnt; i++)
				{	
					if(index == i)
					{
						template.set(EKK1091D010CBSMsg.SVC_KEI_NO, svc_kei_no.get(i));
					}
				}
			}
			/* ++++++++++++++++ v1.00.00 追加終了 +++++++++++++++++++++++++ */
		}
		else
		{
			template.set(EKK1091D010CBSMsg.SVC_KEI_NO, (String)inMap.get("svc_kei_no"));
		}

		// 進捗登録マップ.サービス契約内訳番号 → サービス契約内訳番号
		if ("".equals(inMap.get("svc_kei_ucwk_no")))
		{
			template.setNull(EKK1091D010CBSMsg.SVC_KEI_UCWK_NO);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.SVC_KEI_UCWK_NO, (String)inMap.get("svc_kei_ucwk_no"));
		}

		// 進捗登録マップ.サービス契約回線内訳番号 → サービス契約回線内訳番号
		if ("".equals(inMap.get("svc_kei_kaisen_ucwk_no")))
		{
			template.setNull(EKK1091D010CBSMsg.SVC_KEI_KAISEN_UCWK_NO);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.SVC_KEI_KAISEN_UCWK_NO, (String)inMap.get("svc_kei_kaisen_ucwk_no"));
		}

		// 進捗登録マップ.機器提供サービス契約番号 → 機器提供サービス契約番号
		if ("".equals(inMap.get("kktk_svc_kei_no")))
		{
			template.setNull(EKK1091D010CBSMsg.KKTK_SVC_KEI_NO);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.KKTK_SVC_KEI_NO, (String)inMap.get("kktk_svc_kei_no"));
		}

		// 進捗登録マップ.オプションサービス契約番号 → オプションサービス契約番号
		if ("".equals(inMap.get("op_svc_kei_no")))
		{
			template.setNull(EKK1091D010CBSMsg.OP_SVC_KEI_NO);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.OP_SVC_KEI_NO, (String)inMap.get("op_svc_kei_no"));
		}

		// 進捗登録マップ.請求オプションサービス契約番号 → 請求オプションサービス契約番号
		if ("".equals(inMap.get("seiopsvc_kei_no")))
		{
			template.setNull(EKK1091D010CBSMsg.SEIOPSVC_KEI_NO);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.SEIOPSVC_KEI_NO, (String)inMap.get("seiopsvc_kei_no"));
		}

		// 進捗登録マップ.サブオプションサービス契約番号 → サブオプションサービス契約番号
		if ("".equals(inMap.get("sbop_svc_kei_no")))
		{
			template.setNull(EKK1091D010CBSMsg.SBOP_SVC_KEI_NO);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.SBOP_SVC_KEI_NO, (String)inMap.get("sbop_svc_kei_no"));
		}

		// 進捗登録マップ.割引サービス契約番号 → 割引サービス契約番号
		if ("".equals(inMap.get("wrib_svc_kei_no")))
		{
			template.setNull(EKK1091D010CBSMsg.WRIB_SVC_KEI_NO);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.WRIB_SVC_KEI_NO, (String)inMap.get("wrib_svc_kei_no"));
		}

		// 進捗登録マップ.異動区分 → 異動区分
		if ("".equals(inMap.get("ido_div")))
		{
			template.setNull(EKK1091D010CBSMsg.IDO_DIV);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.IDO_DIV, (String)inMap.get("ido_div"));
		}

		// 進捗登録マップ.異動年月日時分秒 → 異動年月日時分秒
		/*if ("".equals(inMap.get("ido_dtm")))
		{
			template.setNull(EKK1091D010CBSMsg.IDO_DTM);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.IDO_DTM, (String)inMap.get("ido_dtm"));
		}*/
		// 運用日付タイムスタンプ取得
		template.set(EKK1091D010CBSMsg.IDO_DTM, JFUBPCommon.getSysDateTimeStamp());

		// 進捗登録マップ.進捗ステータス → 進捗ステータス
		if ("".equals(inMap.get("prg_stat")))
		{
			template.setNull(EKK1091D010CBSMsg.PRG_STAT);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.PRG_STAT, (String)inMap.get("prg_stat"));
		}

		// 進捗登録マップ.進捗メモ → 進捗メモ
		if ("".equals(inMap.get("prg_memo")))
		{
			template.setNull(EKK1091D010CBSMsg.PRG_MEMO);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.PRG_MEMO, (String)inMap.get("prg_memo"));
		}

		// 進捗登録マップ.進捗特記事項１ → 進捗特記事項1
		// No255 Otsuka 2013/01/26 start
		template.set(EKK1091D010CBSMsg.PRG_TKJK_1, JCCBPCommon.getOpeDateTime(null));
//		if ("".equals(inMap.get("prg_tkjk_1")))
//		{
//			template.setNull(EKK1091D010CBSMsg.PRG_TKJK_1);
//		}
//		else
//		{
//			template.set(EKK1091D010CBSMsg.PRG_TKJK_1, (String)inMap.get("prg_tkjk_1"));
//		}
		// No255 Otsuka 2013/01/26 end

		// 進捗登録マップ.進捗特記事項２ → 進捗特記事項2
		if ("".equals(inMap.get("prg_tkjk_2")))
		{
			template.setNull(EKK1091D010CBSMsg.PRG_TKJK_2);
		}
		else
		{
			template.set(EKK1091D010CBSMsg.PRG_TKJK_2, (String)inMap.get("prg_tkjk_2"));
		}

		// 異動理由明細
		inList = (ArrayList)inMap.get("EKK1091D010CBSMsg1List");
		templateArray = template.getCAANMsgList(EKK1091D010CBSMsg.EKK1091D010CBSMSG1LIST);

		if (templateArray == null)
		{
			templateArray = new CAANMsg[inList.size()];
		}

		if (inList != null)
		{
			for (int i = 0; i < inList.size(); i++)
			{
				HashMap childMap = (HashMap)inList.get(i);

				CAANMsg childTemplate = templateArray[i];
				if (childTemplate == null)
				{
					childTemplate = new CAANMsg(EKK1091D010CBSMsg1List.class.getName());
				}
				// 進捗登録マップ.異動理由コード → 進捗登録.異動理由コード
				if ("".equals(childMap.get("ido_rsn_cd")))
				{
					childTemplate.setNull(EKK1091D010CBSMsg1List.IDO_RSN_CD);
				}
				else
				{
					childTemplate.set(EKK1091D010CBSMsg1List.IDO_RSN_CD, (String)childMap.get("ido_rsn_cd"));
				}
				// 進捗登録マップ.異動理由メモ → 進捗登録.異動理由メモ
				if ("".equals(childMap.get("ido_rsn_memo")))
				{
					childTemplate.setNull(EKK1091D010CBSMsg1List.IDO_RSN_MEMO);
				}
				else
				{
					childTemplate.set(EKK1091D010CBSMsg1List.IDO_RSN_MEMO, (String)childMap.get("ido_rsn_memo"));
				}
				templateArray[i] = childTemplate;
			}
		}
		template.set(EKK1091D010CBSMsg.EKK1091D010CBSMSG1LIST, templateArray);

		return template;
	}

	/**
	 *<DL>
	 *<DT>進捗登録エラーマッピング:
	 *<DD>サービスコンポーネント実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 *<DT>入力パラメータ説明:
	 *<DD>特になし
	 *<DT>入力パラメータ説明：
	 *<DD>特になし
	 *<DT>出力パラメータ説明:
	 *<DD>特になし
	 *</DL>
	 * @param param (I) 業務データ取得・書込用I/F
	 * @param templates (I) CAANMsgクラス配列
	 * @param returnCode (I) リターンコード
	 * @return 業務データ取得・書込用I/F
	 * @since 2011.07.14
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite editErrorInfoEKK1091D010(IRequestParameterReadWrite param, CAANMsg template, int returnCode, String fixedText, int index)
			throws RequestParameterException
	{
		/*		CAANMsg template = templates[0];
				CAANMsg[] templateArray = null;
		*/
		int templateStatus = template.getInt(EKK1091D010CBSMsg.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 inMap = null;
		ArrayList inList = null;

		// 作業項目領域
		Map workMap = (Map)param.getMappingWorkArea();

		/* ユーザデータ情報 */
		inMap = (HashMap)param.getData("EKK1091D010");
		/* ++++++++++++++++ v1.00.00 追加開始 +++++++++++++++++++++ */
		inMap = (HashMap)((ArrayList)inMap.get("EKK1091D010List")).get(index);
		/* ++++++++++++++++ v1.00.00 追加終了 +++++++++++++++++++++ */

		// 進捗登録マップ.申込明細番号 → 申込明細番号 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.MSKM_DTL_NO_ERR))
		{
			if (!inMap.containsKey("mskm_dtl_no_err"))
			{
				inMap.put("mskm_dtl_no_err", template.getString(EKK1091D010CBSMsg.MSKM_DTL_NO_ERR));
			}
		}
		// 進捗登録マップ.請求契約番号 → 請求契約番号 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.SEIKY_KEI_NO_ERR))
		{
			if (!inMap.containsKey("seiky_kei_no_err"))
			{
				inMap.put("seiky_kei_no_err", template.getString(EKK1091D010CBSMsg.SEIKY_KEI_NO_ERR));
			}
		}
		// 進捗登録マップ.請求方法番号（口座） → 請求方法番号(口座) のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.SEIKY_WAY_NO_KOZA_ERR))
		{
			if (!inMap.containsKey("seiky_way_no_koza_err"))
			{
				inMap.put("seiky_way_no_koza_err", template.getString(EKK1091D010CBSMsg.SEIKY_WAY_NO_KOZA_ERR));
			}
		}
		// 進捗登録マップ.請求方法番号（クレジットカード） → 請求方法番号(クレジットカード) のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.SEIKY_WAY_NO_CRECARD_ERR))
		{
			if (!inMap.containsKey("seiky_way_no_crecard_err"))
			{
				inMap.put("seiky_way_no_crecard_err", template.getString(EKK1091D010CBSMsg.SEIKY_WAY_NO_CRECARD_ERR));
			}
		}
		// 進捗登録マップ.サービス契約番号 → サービス契約番号 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.SVC_KEI_NO_ERR))
		{
			if (!inMap.containsKey("svc_kei_no_err"))
			{
				inMap.put("svc_kei_no_err", template.getString(EKK1091D010CBSMsg.SVC_KEI_NO_ERR));
			}
		}
		// 進捗登録マップ.サービス契約内訳番号 → サービス契約内訳番号 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.SVC_KEI_UCWK_NO_ERR))
		{
			if (!inMap.containsKey("svc_kei_ucwk_no_err"))
			{
				inMap.put("svc_kei_ucwk_no_err", template.getString(EKK1091D010CBSMsg.SVC_KEI_UCWK_NO_ERR));
			}
		}
		// 進捗登録マップ.サービス契約回線内訳番号 → サービス契約回線内訳番号 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.SVC_KEI_KAISEN_UCWK_NO_ERR))
		{
			if (!inMap.containsKey("svc_kei_kaisen_ucwk_no_err"))
			{
				inMap.put("svc_kei_kaisen_ucwk_no_err", template.getString(EKK1091D010CBSMsg.SVC_KEI_KAISEN_UCWK_NO_ERR));
			}
		}
		// 進捗登録マップ.機器提供サービス契約番号 → 機器提供サービス契約番号 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.KKTK_SVC_KEI_NO_ERR))
		{
			if (!inMap.containsKey("kktk_svc_kei_no_err"))
			{
				inMap.put("kktk_svc_kei_no_err", template.getString(EKK1091D010CBSMsg.KKTK_SVC_KEI_NO_ERR));
			}
		}
		// 進捗登録マップ.オプションサービス契約番号 → オプションサービス契約番号 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.OP_SVC_KEI_NO_ERR))
		{
			if (!inMap.containsKey("op_svc_kei_no_err"))
			{
				inMap.put("op_svc_kei_no_err", template.getString(EKK1091D010CBSMsg.OP_SVC_KEI_NO_ERR));
			}
		}
		// 進捗登録マップ.請求オプションサービス契約番号 → 請求オプションサービス契約番号 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.SEIOPSVC_KEI_NO_ERR))
		{
			if (!inMap.containsKey("seiopsvc_kei_no_err"))
			{
				inMap.put("seiopsvc_kei_no_err", template.getString(EKK1091D010CBSMsg.SEIOPSVC_KEI_NO_ERR));
			}
		}
		// 進捗登録マップ.サブオプションサービス契約番号 → サブオプションサービス契約番号 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.SBOP_SVC_KEI_NO_ERR))
		{
			if (!inMap.containsKey("sbop_svc_kei_no_err"))
			{
				inMap.put("sbop_svc_kei_no_err", template.getString(EKK1091D010CBSMsg.SBOP_SVC_KEI_NO_ERR));
			}
		}
		// 進捗登録マップ.割引サービス契約番号 → 割引サービス契約番号 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.WRIB_SVC_KEI_NO_ERR))
		{
			if (!inMap.containsKey("wrib_svc_kei_no_err"))
			{
				inMap.put("wrib_svc_kei_no_err", template.getString(EKK1091D010CBSMsg.WRIB_SVC_KEI_NO_ERR));
			}
		}
		// 進捗登録マップ.異動区分 → 異動区分 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.IDO_DIV_ERR))
		{
			if (!inMap.containsKey("ido_div_err"))
			{
				inMap.put("ido_div_err", template.getString(EKK1091D010CBSMsg.IDO_DIV_ERR));
			}
		}
		// 進捗登録マップ.進捗ステータス → 進捗ステータス のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.PRG_STAT_ERR))
		{
			if (!inMap.containsKey("prg_stat_err"))
			{
				inMap.put("prg_stat_err", template.getString(EKK1091D010CBSMsg.PRG_STAT_ERR));
			}
		}
		// 進捗登録マップ.進捗メモ → 進捗メモ のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.PRG_MEMO_ERR))
		{
			if (!inMap.containsKey("prg_memo_err"))
			{
				inMap.put("prg_memo_err", template.getString(EKK1091D010CBSMsg.PRG_MEMO_ERR));
			}
		}
		// 進捗登録マップ.進捗特記事項１ → 進捗特記事項1 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.PRG_TKJK_1_ERR))
		{
			if (!inMap.containsKey("prg_tkjk_1_err"))
			{
				inMap.put("prg_tkjk_1_err", template.getString(EKK1091D010CBSMsg.PRG_TKJK_1_ERR));
			}
		}
		// 進捗登録マップ.進捗特記事項２ → 進捗特記事項2 のエラー情報返却
		if (!template.isNull(EKK1091D010CBSMsg.PRG_TKJK_2_ERR))
		{
			if (!inMap.containsKey("prg_tkjk_2_err"))
			{
				inMap.put("prg_tkjk_2_err", template.getString(EKK1091D010CBSMsg.PRG_TKJK_2_ERR));
			}
		}
		return param;
	}

	/**
	 *<DL>
	 *<DT>進捗登録下りマッピング:
	 *<DD>サービスコンポーネント実行後に、IRequestParameterReadWriteに必要なデータをマッピングする
	 *<DT>入力パラメータ説明:
	 *<DD>特になし
	 *<DT>入力パラメータ説明：
	 *<DD>特になし
	 *<DT>出力パラメータ説明:
	 *<DD>特になし
	 *</DL>
	 * @param msgList (I) CAANMsgクラス 
	 * @param param (I) 業務データ取得・書込用I/F
	 * @return 業務データ取得・書込用I/F
	 * @since 2011.07.14
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite editRetEKK1091D010(Map<?, ?> msgList, IRequestParameterReadWrite param, String fixedText,int index) 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);

		// 作業領域の取得
		Map workMap = (Map)param.getMappingWorkArea();
		if (workMap == null)
		{
			workMap = new HashMap();
			param.setMappingWorkArea(workMap);
		}

		// 結果を詰めるマップを取得。
		HashMap dataMap = null;
		ArrayList dataList = null;

		/* 業務データ設定 */
		dataMap = (HashMap)param.getData(fixedText);
		if (dataMap == null)
		{
			dataMap = new HashMap();
			param.setData(fixedText, dataMap);
		}

		// ++++++++++++++++++++ v1.00.00 追加開始 ++++++++++++++++++++++++++ */
		dataList = (ArrayList)dataMap.get("EKK1091D010List");
		if (dataList == null)
		{
			dataList = new ArrayList();
			dataMap.put("EKK1091D010List", dataList);
		}

		HashMap childMap = (HashMap)dataList.get(index);
		if (childMap == null)
		{
			childMap = new HashMap();
			dataList.add(index, childMap);
		}
		// +++++++++++++++++++ v1.00.00 追加終了 +++++++++++++++++++++++++++ */

		// 進捗登録マップ.進捗番号 ← 進捗番号
		if (parentTemplate.isNull(EKK1091D010CBSMsg.PRG_NO))
		{
			childMap.put("prg_no", new String());
		}
		else
		{
			childMap.put("prg_no", parentTemplate.getString(EKK1091D010CBSMsg.PRG_NO));
		}

		// 進捗登録マップ.異動年月日時分秒 ← 異動年月日時分秒
		if (parentTemplate.isNull(EKK1091D010CBSMsg.IDO_DTM))
		{
			childMap.put("ido_dtm", new String());
		}
		else
		{
			childMap.put("ido_dtm", parentTemplate.getString(EKK1091D010CBSMsg.IDO_DTM));
		}

		// 進捗登録マップ.進捗年月日時分秒 ← 進捗年月日時分秒
		if (parentTemplate.isNull(EKK1091D010CBSMsg.PRG_DTM))
		{
			childMap.put("prg_dtm", new String());
		}
		else
		{
			childMap.put("prg_dtm", parentTemplate.getString(EKK1091D010CBSMsg.PRG_DTM));
		}

		// 進捗登録マップ.登録年月日時分秒 ← 登録年月日時分秒
		if (parentTemplate.isNull(EKK1091D010CBSMsg.ADD_DTM))
		{
			childMap.put("add_dtm", new String());
		}
		else
		{
			childMap.put("add_dtm", parentTemplate.getString(EKK1091D010CBSMsg.ADD_DTM));
		}

		// 進捗登録マップ.登録オペレータアカウント ← 登録オペレータアカウント
		if (parentTemplate.isNull(EKK1091D010CBSMsg.ADD_OPEACNT))
		{
			childMap.put("add_opeacnt", new String());
		}
		else
		{
			childMap.put("add_opeacnt", parentTemplate.getString(EKK1091D010CBSMsg.ADD_OPEACNT));
		}

		// 進捗登録マップ.更新年月日時分秒 ← 更新年月日時分秒
		if (parentTemplate.isNull(EKK1091D010CBSMsg.UPD_DTM))
		{
			childMap.put("upd_dtm", new String());
		}
		else
		{
			childMap.put("upd_dtm", parentTemplate.getString(EKK1091D010CBSMsg.UPD_DTM));
		}

		// 進捗登録マップ.更新オペレータアカウント ← 更新オペレータアカウント
		if (parentTemplate.isNull(EKK1091D010CBSMsg.UPD_OPEACNT))
		{
			childMap.put("upd_opeacnt", new String());
		}
		else
		{
			childMap.put("upd_opeacnt", parentTemplate.getString(EKK1091D010CBSMsg.UPD_OPEACNT));
		}

		// 進捗登録マップ.無効フラグ ← 無効フラグ
		if (parentTemplate.isNull(EKK1091D010CBSMsg.MK_FLG))
		{
			childMap.put("mk_flg", new String());
		}
		else
		{
			childMap.put("mk_flg", parentTemplate.getString(EKK1091D010CBSMsg.MK_FLG));
		}

		// エラー情報の設定
		editErrorInfoEKK1091D010(param, parentTemplate, (Integer)return_code, fixedText,index);

		//エラー情報のマップを取得
		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));
		return param;
	}

	/**
	 * エラー情報のマッピング処理
	 * <br>
	 */
	public IRequestParameterReadWrite editErrorInfo(IRequestParameterReadWrite param, CAANMsg[] templates, int returnCode)
			throws RequestParameterException
	{
		/* ユーザデータ情報 */
		HashMap inMapChk = (HashMap)(param.getData("EKK1091D010"));
		if (inMapChk == null)
		{
			return param;
		}
		// No708 2013/04/24 Otsuka start
		HashMap inMap = (HashMap)param.getData("EKK1091D010");
		int mapCnt = ((ArrayList)inMap.get("EKK1091D010List")).size();
		for (int i = 0; i < mapCnt; i++)
		{
			// 進捗登録
			editErrorInfoEKK1091D010(param, templates[i], returnCode, "EKK1091D010",i);
		}
		// No708 2013/04/24 Otsuka end

		return param;
	}

	/**
	 * コントロールマップエラー情報格納処理
	 * <br>
	 */
	private IRequestParameterReadWrite setControlMapErrInfo(IRequestParameterReadWrite param, int templateStatus, int returnCode)
			throws RequestParameterException
	{
		if (returnCode != 0)
		{
			templateStatus = 9000;
		}
		if (JCMAPLConstMgr.getString(RETURN_MESSAGE_STRING + String.format(RETURN_MESSAGE_FORMAT, 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)
		{
			String formatStatus = String.format(RETURN_MESSAGE_FORMAT, templateStatus);
			String message = JCMAPLConstMgr.getString(RETURN_MESSAGE_STRING + formatStatus);
			param.setControlMapData(SCControlMapKeys.RETURN_CODE, formatStatus);
			param.setControlMapData(SCControlMapKeys.RETURN_MESSAGE, message);
		}
		return param;
	}

}
