/*********************************************************************
*	All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：JCHPrcAdjMappingParts
*   ソースファイル名：JCHPrcAdjMappingParts.java
*   作成者          ：富士通
*   日付            ：2011年09月28日
*＜機能概要＞
*   料金調整マッピング呼出部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/09/28	富士通		新規作成
*
**********************************************************************/
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.exception.RequestParameterException;
import com.fujitsu.futurity.bp.x21.bpm.parameter.IRequestParameterReadOnly;

/**
 * 料金調整(料金変更)サービスにおけるBP-サービスIFマッピング処理で呼び出される部品です。<p>
 * <BR>
 * @author 富士通
 */
public class JCHPrcAdjMappingParts {
	
	/**
	 * 請求一意照会サービスインターフェイスの上りに
	 * マッピングする請求番号を取得する。
	 * 請求一意照会マップのKEY_請求番号に値が設定されている場合は、同入力値を取得し、
	 * 設定されていない場合は、
	 * 請求一覧照会サービスインターフェースの下り明細の先頭行から取得する。
	 * <br>
	 * @param param リクエストパラメータ操作クラス
	 * @param scNameSeikyIcrn 請求一覧照会SC名
	 * @param scNameSeikyIchi 請求一意照会SC名
	 * @return 請求番号
	 * @throws RequestParameterException 
	 */
	public static String getSeikyNo(IRequestParameterReadOnly param, String scNameSeikyIcrn, String scNameSeikyIchi) throws RequestParameterException {
		
		String seikyNo = null;
		
		// 請求一意照会マップより請求番号を取得する
		HashMap dataMap = (HashMap)param.getData(scNameSeikyIchi);
		if (dataMap != null)
		{
			String keySeikyNo = (String)dataMap.get("key_seiky_no");
			if (keySeikyNo != null && "".equals(keySeikyNo) == false)
			{
				seikyNo = keySeikyNo;
			}
		}
		
		// マップより取得できなかった場合、請求一覧照会下り先頭行より請求番号を取得する
		if (seikyNo == null)
		{
			try
			{
				seikyNo = JPCBPCommon.getBPListValueString(param, scNameSeikyIcrn, "ECH0051B010CBSMsg1List", 0, "seiky_no");
			}
			catch (NullPointerException ex)
			{
				seikyNo = null;
			}
		}
		
		return seikyNo;
	}
	
	/**
	 * 債権一覧照会サービスインターフェイスの上りに
	 * マッピングする請求年月を取得する。
	 * 債権一覧照会マップのKEY_請求年月に値が設定されている場合は、同入力値を取得し、
	 * 設定されていない場合は、
	 * 請求一覧照会サービスインターフェースの下り明細の先頭行から取得する。
	 * <br>
	 * @param param リクエストパラメータ操作クラス
	 * @param scNameSeikyIcrn 請求一覧照会SC名
	 * @param scNameSaikenIcrn 債権一覧照会SC名
	 * @return 請求年月
	 * @throws RequestParameterException 
	 */
	public static String getSeikyYm(IRequestParameterReadOnly param, String scNameSeikyIcrn, String scNameSaikenIcrn) throws RequestParameterException {
		
		String seikyYm = null;
		
		// 債権一覧照会マップより請求年月を取得する
		HashMap dataMap = (HashMap)param.getData(scNameSaikenIcrn);
		if (dataMap != null)
		{
			String keySeikyYm = (String)dataMap.get("key_seiky_ym");
			if (keySeikyYm != null && "".equals(keySeikyYm) == false)
			{
				seikyYm = keySeikyYm;
			}
		}
		
		// マップより取得できなかった場合、請求一覧照会下り先頭行より請求年月を取得する
		if (seikyYm == null)
		{
			try
			{
				seikyYm = JPCBPCommon.getBPListValueString(param, scNameSeikyIcrn, "ECH0051B010CBSMsg1List", 0, "seiky_ym");
			}
			catch (NullPointerException ex)
			{
				seikyYm = null;
			}
		}
		
		return seikyYm;
	}
}
