###前提・実現したいこと
EC-CUBEのカスタマイズを行っています。
・同じ名前の営業所(name)が登録されたとき
・同じ名前の営業所短縮名称(short_name)が登録されたとき
上記のときにそれぞれアラートメッセージが出て登録できないようにしたいです、
どのように直したらよいでしょうか?
###発生している問題・エラーメッセージ
エラーは出ないのですが、営業所短縮名称の判断しか動作しておらず、
営業所短縮名称が重複していると営業所名のほうまでエラーが出てしまいます。
###該当のソースコード
PHP
1 2 public function lfCheckError(&$objFormParam) 3 { 4 $arrErr = $objFormParam->checkError(); 5 $post = $objFormParam->getHashArray(); 6 7 $objErr = new SC_CheckError_Ex($post); 8 $objErr->doFunc(array('郵便番号', 'zip01', 'zip02'), array('ALL_EXIST_CHECK')); 9 10 // 電話番号チェック 11 $objErr->doFunc(array('TEL', 'tel01', 'tel02', 'tel03'), array('TEL_CHECK')); 12 $objErr->doFunc(array('フリーダイヤル', 'toll_free01', 'toll_free02', 'toll_free03'), array('TEL_CHECK')); 13 $objErr->doFunc(array('FAX', 'fax01', 'fax02', 'fax03'), array('TEL_CHECK')); 14 15 if (!isset($objErr->arrErr['name'])) { 16 $arrRet = $objFormParam->getHashArray(); 17 // 既存チェック 18 $objOffice = new SC_Helper_Office_Ex(); 19 if ($objOffice->checkExist($arrRet)) { 20 $objErr->arrErr['name'] = '※ 同じ営業所名は登録できません。<br>'; 21 } 22 } 23 if (!isset($objErr->arrErr['short_name'])) { 24 $arrRet = $objFormParam->getHashArray(); 25 // 既存チェック 26 $objOffice = new SC_Helper_Office_Ex(); 27 if ($objOffice->checkExist($arrRet)) { 28 $objErr->arrErr['short_name'] = '※ 同じ名称は登録できません。<br>'; 29 } 30 } 31 return array_merge((array) $arrErr, (array) $objErr->arrErr); 32 } 33 34//SC_Helper_Office() 35 36 37 public function checkExist($arrOffice) 38 { 39 $objDb = new SC_Helper_DB_Ex(); 40 if ($arrOffice['office_id'] == '') { 41 $ret = $objDb->sfIsRecord('dtb_office', 'name', array($arrOffice['name'])); 42 } else { 43 $objQuery =& SC_Query_Ex::getSingletonInstance(); 44 $ret = (($objQuery->count('dtb_office', 'office_id != ? AND name = ? AND del_flg = 0', array($arrOffice['office_id'], $arrOffice['name'])) > 0) ? true : false); 45 } 46 if ($arrOffice['office_id'] == '') { 47 $ret = $objDb->sfIsRecord('dtb_office', 'short_name', array($arrOffice['short_name'])); 48 } else { 49 $objQuery =& SC_Query_Ex::getSingletonInstance(); 50 $ret = (($objQuery->count('dtb_office', 'office_id != ? AND short_name = ? AND del_flg = 0', array($arrOffice['office_id'], $arrOffice['short_name'])) > 0) ? true : false); 51 } 52 53 return $ret; 54 }
###試したこと
課題に対してアプローチしたことを記載してください
###補足情報(言語/FW/ツール等のバージョンなど)
より詳細な情報
あなたの回答
tips
プレビュー