/*******************************************************************************
* All Rights reserved,Copyright (c) K-Opticom
********************************************************************************
*＜プログラム内容＞
* システム名        ：eo顧客基幹システム
* モジュール名      ：JCHCalcTeizoRyokinCC
* ソースファイル名  ：JCHCalcTeizoRyokinCC.java
* 作成者            ：富士通
* 日付              ：2012年06月11日
*＜機能概要＞
* 逓増料金取得コモンコンポーネント部品
*＜修正履歴＞
* バージョン    修正日      修正者      修正内容
* ｖ1.00.00
* ｖ8.00.00    2014/04/09   FJ) 林     【OM-2014-0001415】FTTH従量制サービス消費税対応
*
********************************************************************************/

package com.fujitsu.futurity.bp.custom.common;

import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
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.SCCallException;
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.util.JACCommonUtil;
import eo.common.util.JCRUtilCommon;
import eo.ejb.cbs.cbsmsg.EAC0291B001CBSMsg;
import eo.ejb.cbs.cbsmsg.EAC0291B001CBSMsg1List;

/**
 * 逓増料金取得コモンコンポーネント部品.<br>
 * 
 * @author user
 *
 */
public class JCHCalcTeizoRyokinCC extends AbstractCommonComponent
{
	/**
	 * テンプレートID（逓増料金一覧照会）
	 */
	private static final String TEMPLATE_ID_EAC0291 = "EAC0291B001";

	/**
	 * マップCCID
	 */
	private static final String MAP_CC_ID = "CALCTEIZORYOKINCC";

	/**
	 * 逓増料金一覧照会チェック処理.<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 = editInMsg(param);

		return paramMap;
	}

	/**
	 *逓増料金一覧照会用メッセージ設定処理.<br>
	 * @param param リクエストパラメータ
	 * @return HashMap<String, Object>
	 * @throws RequestParameterException
	 */
	@SuppressWarnings("unchecked")
	public HashMap<String, Object> editInMsg(IRequestParameterReadWrite param) throws RequestParameterException
	{
		HashMap<String, Object> paramMap = new HashMap<String, Object>();

		/* 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));

		/* ユーザデータ情報 */
		HashMap<String, Object> inMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		if (inMap == null)
		{
			inMap = new HashMap<String, Object>();
			param.setData(MAP_CC_ID, inMap);
		}

		CAANMsg template = new CAANMsg(EAC0291B001CBSMsg.class.getName());
		// テンプレートID
		template.set(EAC0291B001CBSMsg.TEMPLATEID, TEMPLATE_ID_EAC0291);

		// 機能コード（デフォルト：１）
		template.set(EAC0291B001CBSMsg.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);

		// ◇業務データの設定
		// 機能コード
		template.set(EAC0291B001CBSMsg.FUNC_CODE, inMap.get(JCMConstants.FUNC_CODE_KEY));

		// 逓増料金取得CCマップ.ＫＥＹ＿システムコード → ＫＥＹ＿システムコード
		if (JCRUtilCommon.isNull(inMap.get("key_sys_cd")))
		{
			template.setNull(EAC0291B001CBSMsg.KEY_SYS_CD);
		}
		else
		{
			template.set(EAC0291B001CBSMsg.KEY_SYS_CD, (String)inMap.get("key_sys_cd"));
		}

		// 逓増料金取得CCマップ.ＫＥＹ＿料金コースコード → ＫＥＹ＿料金コースコード
		if (JCRUtilCommon.isNull(inMap.get("key_pcrs_cd")))
		{
			template.setNull(EAC0291B001CBSMsg.KEY_PCRS_CD);
		}
		else
		{
			template.set(EAC0291B001CBSMsg.KEY_PCRS_CD, (String)inMap.get("key_pcrs_cd"));
		}

		// 逓増料金取得CCマップ.ＫＥＹ＿料金サービスコード → ＫＥＹ＿料金サービスコード
		if (JCRUtilCommon.isNull(inMap.get("key_prc_svc_cd")))
		{
			template.setNull(EAC0291B001CBSMsg.KEY_PRC_SVC_CD);
		}
		else
		{
			template.set(EAC0291B001CBSMsg.KEY_PRC_SVC_CD, (String)inMap.get("key_prc_svc_cd"));
		}

		// 逓増料金取得CCマップ.ＫＥＹ＿相対番号 → ＫＥＹ＿相対番号
		if (JCRUtilCommon.isNull(inMap.get("key_aitai_no")))
		{
			template.setNull(EAC0291B001CBSMsg.KEY_AITAI_NO);
		}
		else
		{
			template.set(EAC0291B001CBSMsg.KEY_AITAI_NO, (String)inMap.get("key_aitai_no"));
		}

		// 逓増料金取得CCマップ.ＫＥＹ＿対象料金項目コード → ＫＥＹ＿対象料金項目コード
		if (JCRUtilCommon.isNull(inMap.get("key_tg_prc_kmk_cd")))
		{
			template.setNull(EAC0291B001CBSMsg.KEY_TG_PRC_KMK_CD);
		}
		else
		{
			template.set(EAC0291B001CBSMsg.KEY_TG_PRC_KMK_CD, (String)inMap.get("key_tg_prc_kmk_cd"));
		}

		// 逓増料金取得CCマップ.請求年月 → ＫＥＹ＿基準年月
		if (JCRUtilCommon.isNull(inMap.get("seiky_ym")))
		{
			template.setNull(EAC0291B001CBSMsg.KEY_STANDARD_YM);
		}
		else
		{
			template.set(EAC0291B001CBSMsg.KEY_STANDARD_YM, (String)inMap.get("seiky_ym"));
		}

		CAANMsg[] templates = new CAANMsg[1];
		templates[0] = template;
		paramMap.put(JCMConstants.TEMPLATE_LIST_KEY, templates);

		return paramMap;
	}

	/**
	 * サービスコンポーネント実行後に、IRequestParameterReadWriteにエラー情報をマッピングする
	 * @param param リクエストパラメータ
	 * @param templates テンプレート
	 * @param returnCode リターンコード
	 * @return IRequestParameterReadWrite
	 * @throws RequestParameterException RequestParameterException
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite editErrorInfo(IRequestParameterReadWrite param
			, CAANMsg[] templates, int returnCode) throws RequestParameterException
	{
		CAANMsg template = templates[0];

		int templateStatus = template.getInt(EAC0291B001CBSMsg.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 = (HashMap<String, Object>)param.getData(MAP_CC_ID);

		// 逓増料金取得マップ.ＫＥＹ＿システムコードエラー → ＫＥＹ＿システムコードエラー
		if (!template.isNull(EAC0291B001CBSMsg.KEY_SYS_CD_ERR))
		{
			if (!inMap.containsKey("key_sys_cd_err"))
			{
				inMap.put("key_sys_cd_err", template.getString(EAC0291B001CBSMsg.KEY_SYS_CD_ERR));
			}
		}

		// 逓増料金取得マップ.ＫＥＹ＿料金コースコードエラー → ＫＥＹ＿料金コースコードエラー
		if (!template.isNull(EAC0291B001CBSMsg.KEY_PCRS_CD_ERR))
		{
			if (!inMap.containsKey("key_pcrs_cd_err"))
			{
				inMap.put("key_pcrs_cd_err", template.getString(EAC0291B001CBSMsg.KEY_PCRS_CD_ERR));
			}
		}

		// 逓増料金取得マップ.ＫＥＹ＿料金サービスコードエラー → ＫＥＹ＿料金サービスコードエラー
		if (!template.isNull(EAC0291B001CBSMsg.KEY_PRC_SVC_CD_ERR))
		{
			if (!inMap.containsKey("key_prc_svc_cd_err"))
			{
				inMap.put("key_prc_svc_cd_err", template.getString(EAC0291B001CBSMsg.KEY_PRC_SVC_CD_ERR));
			}
		}

		// 逓増料金取得マップ.ＫＥＹ＿相対番号エラー → ＫＥＹ＿相対番号エラー
		if (!template.isNull(EAC0291B001CBSMsg.KEY_AITAI_NO_ERR))
		{
			if (!inMap.containsKey("key_aitai_no_err"))
			{
				inMap.put("key_aitai_no_err", template.getString(EAC0291B001CBSMsg.KEY_AITAI_NO_ERR));
			}
		}

		// 逓増料金取得マップ.ＫＥＹ＿対象料金項目コードエラー → ＫＥＹ＿対象料金項目コードエラー
		if (!template.isNull(EAC0291B001CBSMsg.KEY_TG_PRC_KMK_CD_ERR))
		{
			if (!inMap.containsKey("key_tg_prc_kmk_cd_err"))
			{
				inMap.put("key_tg_prc_kmk_cd_err", template.getString(EAC0291B001CBSMsg.KEY_TG_PRC_KMK_CD_ERR));
			}
		}

		// 逓増料金取得マップ.ＫＥＹ＿基準年月エラー → ＫＥＹ＿基準年月エラー
		if (!template.isNull(EAC0291B001CBSMsg.KEY_STANDARD_YM_ERR))
		{
			if (!inMap.containsKey("key_standard_ym_err"))
			{
				inMap.put("key_standard_ym_err", template.getString(EAC0291B001CBSMsg.KEY_STANDARD_YM_ERR));
			}
		}
		
		return param;
	}

	/**
	 * 逓増料金取得<br>
	 * <br>
	 * 逓増料金一覧照会サービスIFを呼び出し、逓増料金情報を取得する。
	 * 
	 * @param handle セッションハンドル
	 * @param param リクエストパラメータ
	 * @param fixedText サービスメッセージ
	 * @return リクエストパラメータ
	 * @throws Exception Exception
	 */
	@SuppressWarnings("unchecked")
	public IRequestParameterReadWrite calcTeizoRyokin(SessionHandle handle,
			IRequestParameterReadWrite param, String fixedText) throws Exception
	{
		ServiceComponentRequestInvoker scCall = new ServiceComponentRequestInvoker();

		// ユーザデータ情報
		HashMap<String, Object> inMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);

		if (inMap == null)
		{
			inMap = new HashMap<String, Object>();
			param.setData(MAP_CC_ID, inMap);
		}

		// 上りマッピング処理
		HashMap<String, Object> paramMap = editInMsg(param);

		// ＳＣ呼出実行
		Map<?, ?> resultWorkParamShokai = scCall.run(paramMap, handle);

		// ＳＣの実行結果をセット
		setOutputData(resultWorkParamShokai, param);

		// 通信限度額を算出しセット
		calcTsusinUpplValue(param);

		// 逓増料金を算出しセット
		calcTeizoRyokinInfo(param);

		return param;
	}

	/**
	 * 逓増料金一覧照会結果設定処理.<br>
	 * 
	 * @param msgList メッセージリスト
	 * @param param リクエストパラメータ
	 * @return IRequestParameterReadWrite
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite setOutputData(Map<?, ?> msgList,
			IRequestParameterReadWrite param) throws Exception
	{

		// SCからの戻り値からCAANMsgを取得する。
		CAANMsg[] templates = (CAANMsg[])msgList.get(JCMConstants.TEMPLATE_LIST_KEY);
		CAANMsg parentTemplate = templates[0];

		// リターンコード取得
		Object return_code = msgList.get(JCMConstants.RET_CD_INT_KEY);

		/* 業務データ設定 */
		HashMap<String, Object> dataMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		if (dataMap == null)
		{
			dataMap = new HashMap<String, Object>();
			param.setData(MAP_CC_ID, dataMap);
		}

		CAANMsg[] templateArray = parentTemplate.getCAANMsgList(EAC0291B001CBSMsg.EAC0291B001CBSMSG1LIST);

		ArrayList<HashMap<String, Object>> dataList = null;

		if (templateArray != null)
		{
			dataList = new ArrayList<HashMap<String, Object>>();

			for (int i = 0; i < templateArray.length; i++)
			{
				CAANMsg childTemplate = templateArray[i];
				dataList.add(new HashMap<String, Object>());

				HashMap<String, Object> childMap = (HashMap<String, Object>)dataList.get(i);

				// 逓増料金一覧照会マップ.逓増料金一覧照会明細.料金コースコード ← 逓増料金一覧照会明細.料金コースコード
				if (childTemplate.isNull(EAC0291B001CBSMsg1List.PCRS_CD))
				{
					childMap.put("pcrs_cd", "");
				}
				else
				{
					childMap.put("pcrs_cd", childTemplate.getString(EAC0291B001CBSMsg1List.PCRS_CD));
				}

				// 逓増料金一覧照会マップ.逓増料金一覧照会明細.料金サービスコード ← 逓増料金一覧照会明細.料金サービスコード
				if (childTemplate.isNull(EAC0291B001CBSMsg1List.PRC_SVC_CD))
				{
					childMap.put("prc_svc_cd", "");
				}
				else
				{
					childMap.put("prc_svc_cd", childTemplate.getString(EAC0291B001CBSMsg1List.PRC_SVC_CD));
				}

				// 逓増料金一覧照会マップ.逓増料金一覧照会明細.対象料金項目コード ← 逓増料金一覧照会明細.対象料金項目コード
				if (childTemplate.isNull(EAC0291B001CBSMsg1List.TG_PRC_KMK_CD))
				{
					childMap.put("tg_prc_kmk_cd", "");
				}
				else
				{
					childMap.put("tg_prc_kmk_cd", childTemplate.getString(EAC0291B001CBSMsg1List.TG_PRC_KMK_CD));
				}

				// 逓増料金一覧照会マップ.逓増料金一覧照会明細.下限値 ← 逓増料金一覧照会明細.下限値
				if (childTemplate.isNull(EAC0291B001CBSMsg1List.LOWL_VALUE))
				{
					childMap.put("lowl_value", "");
				}
				else
				{
					childMap.put("lowl_value", childTemplate.getString(EAC0291B001CBSMsg1List.LOWL_VALUE));
				}

				// 逓増料金一覧照会マップ.逓増料金一覧照会明細.上限値 ← 逓増料金一覧照会明細.上限値
				if (childTemplate.isNull(EAC0291B001CBSMsg1List.UPPL_VALUE))
				{
					childMap.put("uppl_value", "");
				}
				else
				{
					childMap.put("uppl_value", childTemplate.getString(EAC0291B001CBSMsg1List.UPPL_VALUE));
				}

				// 逓増料金一覧照会マップ.逓増料金一覧照会明細.単位 ← 逓増料金一覧照会明細.単位
				if (childTemplate.isNull(EAC0291B001CBSMsg1List.TANI))
				{
					childMap.put("tani", "");
				}
				else
				{
					childMap.put("tani", childTemplate.getString(EAC0291B001CBSMsg1List.TANI));
				}

				// 逓増料金一覧照会マップ.逓増料金一覧照会明細.単価 ← 逓増料金一覧照会明細.単価
				if (childTemplate.isNull(EAC0291B001CBSMsg1List.TANKA))
				{
					childMap.put("tanka", "");
				}
				else
				{
					childMap.put("tanka", childTemplate.getString(EAC0291B001CBSMsg1List.TANKA));
				}

			}
		}
		dataMap.put("EAC0291B001CBSMsg1List", 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);
		
		// 異常の場合、SCCallExceptionを生成してスローする
		if(!("0".equals(rtnCode) && 0 == Integer.parseInt(status))) 
		{
			SCCallException scCallEx = new SCCallException("INVALID_RETURN_MESSAGE", rtnCode, Integer.parseInt(status));
			throw scCallEx;
		}

		return param;
	}

	/**
	 * 通信料限度額算出処理.<br>
	 * 
	 * @param msgList メッセージリスト
	 * @param param リクエストパラメータ
	 * @return IRequestParameterReadWrite
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite calcTsusinUpplValue(IRequestParameterReadWrite param) throws Exception
	{

		/* 業務データ設定 */
		HashMap<String, Object> dataMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		if (dataMap == null)
		{
			dataMap = new HashMap<String, Object>();
			param.setData(MAP_CC_ID, dataMap);
		}

		ArrayList<HashMap<String, Object>> dataList = (ArrayList)dataMap.get("EAC0291B001CBSMsg1List");
		int arraySize = dataList.size();

		if (dataList != null && arraySize != 0)
		{
			// 最終行のオブジェクトを取得
			HashMap<String, Object> teizoMap = dataList.get(arraySize - 1);

			// 最終行の上限額を元に逓増料金を算出し、業務データにセット
			BigDecimal teizoRyokin =  teizoPrc(new BigDecimal((String)teizoMap.get("uppl_value")), dataList);
			dataMap.put("tsusin_uppl_value", teizoRyokin);
		}

		return param;
	}

	/**
	 * 逓増料金算出処理.<br>
	 * 
	 * @param msgList メッセージリスト
	 * @param param リクエストパラメータ
	 * @return IRequestParameterReadWrite
	 * @throws Exception
	 */
	@SuppressWarnings("unchecked")
	private IRequestParameterReadWrite calcTeizoRyokinInfo(IRequestParameterReadWrite param) throws Exception
	{

		/* 業務データ設定 */
		HashMap<String, Object> dataMap = (HashMap<String, Object>)param.getData(MAP_CC_ID);
		if (dataMap == null)
		{
			dataMap = new HashMap<String, Object>();
			param.setData(MAP_CC_ID, dataMap);
		}

		ArrayList<HashMap<String, Object>> dataList = (ArrayList)dataMap.get("EAC0291B001CBSMsg1List");

		// 逓増料金算出リスト
		ArrayList<HashMap<String, Object>> calcTeizoInfoList = (ArrayList<HashMap<String, Object>>)dataMap.get("CALC_TEIZO_INFO_List");

		if (calcTeizoInfoList != null)
		{
			for (int i = 0; i < calcTeizoInfoList.size(); i++)
			{
				HashMap<String, Object> calcInfoMap = (HashMap<String, Object>)calcTeizoInfoList.get(i);

				// 逓増料金算出リスト.通信料を元に逓増料金を算出し、業務データにセット
				BigDecimal teizoRyokin =  teizoPrc(new BigDecimal((String)calcInfoMap.get("amount")), dataList);

				// 逓増料金算出リスト.料金にセット
				calcInfoMap.put("ryokin", teizoRyokin);
			}
		}

		return param;
	}

	/**
	 * 逓増料金を取得します。
	 * 
	 * @param amount 数量
	 * @param teizoMstList 逓増料金マスタのリスト
	 * @return long 逓増料金計算結果
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	private BigDecimal teizoPrc(BigDecimal amount, List<HashMap<String, Object>> teizoMstList) throws Exception
	{
		// 逓増料金
		BigDecimal teizouRyokin = BigDecimal.ZERO;

		for (HashMap<String, Object> teizoMap : teizoMstList) {

			// 段階利用数計算
			BigDecimal wAmount 		= amount;					 							// ワーク（数量）
			BigDecimal lower 		= new BigDecimal((String)teizoMap.get("lowl_value")); 	// 下限値
			BigDecimal upper 		= new BigDecimal((String)teizoMap.get("uppl_value")); 	// 上限値
			BigDecimal riyoCount 	= BigDecimal.ZERO; 										// 利用数

			BigDecimal tani 		= new BigDecimal((String)teizoMap.get("tani")); 	// 単位
			BigDecimal tanka 		= new BigDecimal((String)teizoMap.get("tanka")); 	// 単価

			// 数量≧上限値
			if (amount.compareTo(upper) >= 0)
			{
				// 料金（数量）≧上限値　のため、ワーク料金（数量）←上限値 - 1
				wAmount = upper.subtract(BigDecimal.ONE);
			}

			// 下限値≦ワーク料金＜上限値
			if (lower.compareTo(wAmount) <= 0 && wAmount.compareTo(upper) < 0)
			{
				// 下限値＝０
				if (lower.compareTo(BigDecimal.ZERO) == 0)
				{
					// 利用数←ワーク（数量）
					riyoCount = wAmount;
				}
				// 下限値≠０
				else
				{
					// 利用数←ワーク（数量）- 下限値 + 1
					riyoCount = wAmount.subtract(lower).add(BigDecimal.ONE);
				}

				// 逓増料金計算
				// 利用単位数←利用数／単位（有効桁数小数点第4位まで）
				BigDecimal unitCount = riyoCount.divide(tani, 4, BigDecimal.ROUND_HALF_EVEN);

				// ワーク逓増料金←ワーク逓増料金＋（利用単位数（切り上げ）＊単価）
				// （小数点以下は切り捨てる）
				BigDecimal wkTeizouRyokin = JACCommonUtil.round(JACStrConst.ROUND_UP, unitCount, 0).multiply(tanka);
				teizouRyokin = teizouRyokin.add(JACCommonUtil.round(JACStrConst.ROUND_DOWN, wkTeizouRyokin, 0));
			}
		}
		return teizouRyokin;
	}

}
