Source for file LC_Page_Admin_Order_Edit.php
Documentation is available at LC_Page_Admin_Order_Edit.php
* This file is part of EC-CUBE
* Copyright(c) 2000-2010 LOCKON CO.,LTD. All Rights Reserved.
* http://www.lockon.co.jp/
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
require_once(CLASS_PATH . "pages/LC_Page.php");
if (file_exists(MODULE_PATH . 'mdl_gmopg/inc/include.php') === TRUE) {
require_once(MODULE_PATH . 'mdl_gmopg/inc/include.php');
if (file_exists(MODULE_PATH . 'mdl_paygent/include.php') === TRUE) {
require_once(MODULE_PATH . 'mdl_paygent/include.php');
if (file_exists(MODULE_PATH. 'mdl_fregi/LC_Page_Mdl_Fregi_Config.php') === TRUE) {
require_once(MODULE_PATH. 'mdl_fregi/LC_Page_Mdl_Fregi_Config.php');
if (file_exists(MODULE_PATH . 'mdl_sps/request.php') === TRUE) {
require_once(MODULE_PATH . 'mdl_sps/request.php');
* @author LOCKON CO.,LTD.
$this->tpl_subnavi = 'order/subnavi.tpl';
$this->tpl_subno = 'index';
$this->tpl_subtitle = '受注管理';
if (empty($_GET['order_id']) && empty($_POST['order_id'])) {
$this->tpl_subno = 'add';
$this->tpl_subtitle = '新規受注入力';
$masterData = new SC_DB_MasterData_Ex();
$this->arrPref = $masterData->getMasterData("mtb_pref",
array("pref_id", "pref_name", "rank"));
$this->arrORDERSTATUS = $masterData->getMasterData("mtb_order_status");
$this->arrDispKind = sfPaygentOrderPage();
if (file_exists(MODULE_PATH. 'mdl_fregi/LC_Page_Mdl_Fregi_Config.php') === TRUE) {
$this->arrFregiPayment = $arrFregiPayment;
global $arrFregiDispKind;
$this->arrFregiDispKind = $arrFregiDispKind;
$objDb = new SC_Helper_DB_Ex();
$this->arrYearDelivDate = $objDate->getYear('', date('Y'), '');
$this->arrMonthDelivDate = $objDate->getMonth(true);
$this->arrDayDelivDate = $objDate->getDay(true);
$arrInfo = $objSiteInfo->data;
SC_Utils_Ex::sfIsSuccess($objSess);
foreach ($_POST as $key => $val) {
if (ereg("^search_", $key)) {
$this->arrSearchHidden[$key] = $val;
if(isset ($_GET['order_id']) &&
SC_Utils_Ex::sfIsInt($_GET['order_id'])) {
$order_id = $_GET['order_id'];
$order_id = $_POST['order_id'];
$this->tpl_order_id = $order_id;
$this->objFormParam->setParam($_POST);
$this->objFormParam->convParam();
$this->arrErr = array_merge( (array) $this->arrErr, (array) $this->lfCheek($arrInfo, $_POST['mode']) );
if(count($this->arrErr) == 0) {
if ($_POST['mode'] == 'add') {
$this->tpl_order_id = $order_id;
$this->tpl_mode = 'edit';
$arrData['order_id'] = $order_id;
$this->objFormParam->setParam($arrData);
$text = "'新規受注を登録しました。'";
$text = "'受注履歴を編集しました。'";
$this->objFormParam->setParam($_POST);
$this->objFormParam->convParam();
if(count($this->arrErr) == 0) {
$this->arrErr = $this->lfCheek($arrInfo, $_POST['mode']);
$this->paygent_return = sfPaygentOrder($_POST['paygent_type'], $order_id);
$delete_no = $_POST['delete_no'];
foreach ($_POST AS $key=> $val) {
foreach ($val AS $k=> $v) {
$this->objFormParam->setParam($arrData);
$this->objFormParam->convParam();
/* 商品追加ポップアップより商品選択後、商品情報取得*/
case 'select_product_detail':
$this->objFormParam->setParam($_POST);
if (!empty($_POST['add_product_id'])) {
$this->lfInsertProduct($_POST['add_product_id'], $_POST['add_classcategory_id1'], $_POST['add_classcategory_id2']);
} elseif (!empty($_POST['edit_product_id'])) {
$this->lfUpdateProduct($_POST['edit_product_id'], $_POST['edit_classcategory_id1'], $_POST['edit_classcategory_id2'], $_POST['no']);
foreach ($this->arrForm AS $key=> $val) {
$arrData[$key] = $this->arrForm[$key]['value'];
$this->objFormParam->setParam($arrData);
$this->objFormParam->convParam();
/* 顧客検索ポップアップより顧客指定後、顧客情報取得*/
$this->objFormParam->setParam($_POST);
// 検索結果から顧客IDを指定された場合、顧客情報をフォームに代入する
$objFregiConfig = new LC_Page_Mdl_Fregi_Config();
$this->fregi_err = $objFregiConfig->getSaleInfo($order_id, $this->arrDisp);
$objFregiConfig = new LC_Page_Mdl_Fregi_Config();
$this->fregi_card_err = $objFregiConfig->setCardInfo($_POST['card_status'], $order_id, $this->arrDisp);
$objErr->doFunc(array("年","sps_year"), array('EXIST_CHECK'));
$objErr->doFunc(array("月","sps_month"), array('EXIST_CHECK'));
$objErr->doFunc(array("日","sps_date"), array('EXIST_CHECK'));
$objErr->doFunc(array("売上・返金日", "sps_year", "sps_month", "sps_date"), array("CHECK_DATE"));
$this->arrErr = $objErr->arrErr;
$sps_return = sfSpsRequest( $order_id, $_POST['request_type'] );
$this->tpl_onload = "window.alert('". $sps_return. "');";
require_once(MODULE_PATH . 'mdl_gmopg/class/LC_Mdl_GMOPG_OrderEdit.php');
$objGMOOrderEdit = new LC_MDL_GMOPG_OrderEdit;
$this->gmopg_order_edit_result = $objGMOOrderEdit->proccess();
$this->arrPayment = $objDb->sfGetIDValueList("dtb_payment", "payment_id", "payment_method");
$arrRet = $objDb->sfGetDelivTime($this->objFormParam->getValue('payment_id'));
$this->arrDelivTime = SC_Utils_Ex::sfArrKeyValue($arrRet, 'time_id', 'deliv_time');
$this->arrForm = $this->objFormParam->getFormParamList();
$this->product_count = count($this->arrForm['quantity']['value']);
if (isset ($_POST['anchor_key']) && !empty($_POST['anchor_key'])) {
$anchor_hash = "location.hash='#" . $_POST['anchor_key'] . "'";
$this->arrInfo = $arrInfo;
if (file_exists(MODULE_PATH . 'mdl_sps/request.php') === TRUE) {
$this->paymentType = $objQuery->getAll("SELECT module_code, memo03 FROM dtb_payment WHERE payment_id = ? ", array($this->arrForm["payment_id"]['value']));
$objDate->setStartYear(RELEASE_YEAR);
$this->arrYear = $objDate->getYear();
$this->arrMonth = $objDate->getMonth();
$this->arrDay = $objDate->getDay();
$objView->assignobj($this);
$objView->display(MAIN_FRAME);
$objView->display('order/disp.tpl');
$this->objFormParam->addParam("顧客名1", "order_name01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("顧客名2", "order_name02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("顧客名カナ1", "order_kana01", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("顧客名カナ2", "order_kana02", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("メールアドレス", "order_email", MTEXT_LEN, "KVCa", array("EXIST_CHECK", "NO_SPTAB", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("郵便番号1", "order_zip01", ZIP01_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
$this->objFormParam->addParam("郵便番号2", "order_zip02", ZIP02_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
$this->objFormParam->addParam("都道府県", "order_pref", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
$this->objFormParam->addParam("住所1", "order_addr01", MTEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("住所2", "order_addr02", MTEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("電話番号1", "order_tel01", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
$this->objFormParam->addParam("電話番号2", "order_tel02", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
$this->objFormParam->addParam("電話番号3", "order_tel03", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
$this->objFormParam->addParam("お名前1", "deliv_name01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("お名前2", "deliv_name02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("フリガナ1", "deliv_kana01", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("フリガナ2", "deliv_kana02", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("郵便番号1", "deliv_zip01", ZIP01_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
$this->objFormParam->addParam("郵便番号2", "deliv_zip02", ZIP02_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
$this->objFormParam->addParam("都道府県", "deliv_pref", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
$this->objFormParam->addParam("住所1", "deliv_addr01", MTEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("住所2", "deliv_addr02", MTEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("電話番号1", "deliv_tel01", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
$this->objFormParam->addParam("電話番号2", "deliv_tel02", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
$this->objFormParam->addParam("電話番号3", "deliv_tel03", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
$this->objFormParam->addParam("値引き", "discount", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"), '0');
$this->objFormParam->addParam("送料", "deliv_fee", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"), '0');
$this->objFormParam->addParam("手数料", "charge", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
if( USE_POINT === true ){
$this->objFormParam->addParam("利用ポイント", "use_point", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
$this->objFormParam->addParam("お支払い方法", "payment_id", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
$this->objFormParam->addParam("お届け時間ID", "deliv_time_id", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
$this->objFormParam->addParam("対応状況", "status", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
$this->objFormParam->addParam("お届け日(年)", "deliv_date_year", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
$this->objFormParam->addParam("お届け日(月)", "deliv_date_month", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
$this->objFormParam->addParam("お届け日(日)", "deliv_date_day", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
$this->objFormParam->addParam("お支払方法名称", "payment_method");
$this->objFormParam->addParam("お届け時間", "deliv_time");
$this->objFormParam->addParam("単価", "price", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"), '0');
$this->objFormParam->addParam("個数", "quantity", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"), '0');
$this->objFormParam->addParam("商品ID", "product_id", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"), '0');
$this->objFormParam->addParam("ポイント付与率", "point_rate");
$this->objFormParam->addParam("商品コード", "product_code");
$this->objFormParam->addParam("商品名", "product_name");
$this->objFormParam->addParam("規格1", "classcategory_id1");
$this->objFormParam->addParam("規格2", "classcategory_id2");
$this->objFormParam->addParam("規格名1", "classcategory_name1");
$this->objFormParam->addParam("規格名2", "classcategory_name2");
$this->objFormParam->addParam("メモ", "note", MTEXT_LEN, "KVa", array("MAX_LENGTH_CHECK"));
$this->objFormParam->addParam("小計", "subtotal");
$this->objFormParam->addParam("合計", "total");
$this->objFormParam->addParam("支払い合計", "payment_total");
$this->objFormParam->addParam("加算ポイント", "add_point");
$this->objFormParam->addParam("お誕生日ポイント", "birth_point");
$this->objFormParam->addParam("消費税合計", "tax");
$this->objFormParam->addParam("最終保持ポイント", "total_point");
$this->objFormParam->addParam("顧客ID", "customer_id");
$this->objFormParam->addParam("現在のポイント", "point");
$this->objFormParam->addParam("注文番号", "order_id");
$this->objFormParam->addParam("受注日", "create_date");
$this->objFormParam->addParam("発送日", "commit_date");
$this->objFormParam->addParam("備考", "message");
$this->objFormParam->addParam("お届け日", "deliv_date");
if(SC_Utils_Ex::sfIsInt($order_id)) {
$objDb = new SC_Helper_DB_Ex();
$arrRet = $objQuery->select("*", "dtb_order", $where, array($order_id));
$this->objFormParam->setParam($arrRet[0]);
list ($point, $total_point) = $objDb->sfGetCustomerPoint($order_id, $arrRet[0]['use_point'], $arrRet[0]['add_point']);
$this->objFormParam->setValue('total_point', $total_point);
$this->objFormParam->setValue('point', $point);
if (!empty($arrRet[0]["deliv_date"])) {
$delivDate = mb_strcut($arrRet[0]["deliv_date"], 0, 8);
$delivDate = split("/", $delivDate);
$ts = mktime(0, 0, 0, $delivDate[1], $delivDate[2], $delivDate[0]);
$this->objFormParam->setValue('deliv_date_year', date("Y", $ts));
$this->objFormParam->setValue('deliv_date_month', date("n", $ts));
$this->objFormParam->setValue('deliv_date_day', date("j", $ts));
$this->arrForm = $arrRet[0];
$arrRet = SC_Utils_Ex::sfSwapArray($arrRet);
$this->objFormParam->setParam($arrRet);
if($this->arrForm["memo02"] != "") $this->arrForm["payment_info"] = unserialize($this->arrForm["memo02"]);
if($this->arrForm["memo01"] == PAYMENT_CREDIT_ID){
$this->arrForm["payment_type"] = "クレジット決済";
}elseif($this->arrForm["memo01"] == PAYMENT_CONVENIENCE_ID){
$this->arrForm["payment_type"] = "コンビニ決済";
$this->arrForm["payment_type"] = "お支払い";
//受注データを表示用配列に代入(各EC-CUBEバージョンと決済モジュールとのデータ連携保全のため)
$this->arrDisp = $this->arrForm;
$col = "product_id, classcategory_id1, classcategory_id2, product_code, product_name, classcategory_name1, classcategory_name2, price, quantity, point_rate";
$objQuery->setOrder("classcategory_id1, classcategory_id2");
$arrRet = $objQuery->select($col, "dtb_order_detail", $where, array($order_id));
$arrRet = $this->objFormParam->getHashArray();
$objErr->doFunc(array("お届け日", "deliv_date_year", "deliv_date_month", "deliv_date_day"), array("CHECK_DATE"));
if (count($objErr->arrErr) >= 1) {
return $this->objFormParam->checkError();
function lfCheek($arrInfo,$mode = "") {
$objDb = new SC_Helper_DB_Ex();
$arrVal = $this->objFormParam->getHashArray();
$max = count($arrVal['quantity']);
for($i = 0; $i < $max; $i++ ) {
$subtotal += SC_Utils_Ex::sfPreTax($arrVal['price'][$i], $arrInfo['tax'], $arrInfo['tax_rule']) * $arrVal['quantity'][$i];
$totaltax += SC_Utils_Ex::sfTax($arrVal['price'][$i], $arrInfo['tax'], $arrInfo['tax_rule']) * $arrVal['quantity'][$i];
$totalpoint += SC_Utils_Ex::sfPrePoint($arrVal['price'][$i], $arrVal['point_rate'][$i]) * $arrVal['quantity'][$i];
$productClass = $objDb->sfGetProductsClass(array($arrVal['product_id'][$i],
$arrVal['classcategory_id1'][$i],
$arrVal['classcategory_id2'][$i]));
if ($productClass['stock_unlimited'] != '1'
&& $productClass['stock'] < ($arrVal['quantity'][$i] - $this->arrForm['quantity'][$i])) {
$className1 = $this->arrForm['classcategory_name1'][$i];
$className1 = empty($className1) ? 'なし' : $className1;
$className2 = $this->arrForm['classcategory_name2'][$i];
$className2 = empty($className2) ? 'なし' : $className2;
if (!isset ($arrErr['quantity'])) $arrErr['quantity'] = "";
$arrErr['quantity'] .= $this->arrForm['product_name'][$i] . '/(' . $className1 . ')/(' . $className2 . ') の在庫が不足しています。 設定できる数量は「' . ($this->arrForm['quantity'][$i] + $productClass['stock']) . '」までです。<br />';
$arrVal['tax'] = $totaltax;
$arrVal['subtotal'] = $subtotal;
$arrVal['total'] = $subtotal - $arrVal['discount'] + $arrVal['deliv_fee'] + $arrVal['charge'];
$arrVal['payment_total'] = $arrVal['total'] - ($arrVal['use_point'] * POINT_VALUE);
$arrVal['add_point'] = SC_Utils_Ex::sfGetAddPoint($totalpoint, $arrVal['use_point'], $arrInfo);
if (strlen($_POST['customer_id']) > 0){
list ($arrVal['point'], $arrVal['total_point']) = $objDb->sfGetCustomerPointFromCid($_POST['customer_id'], $arrVal['use_point'], $arrVal['add_point']);
list ($arrVal['point'], $arrVal['total_point']) = $objDb->sfGetCustomerPoint($_POST['order_id'], $arrVal['use_point'], $arrVal['add_point']);
if($arrVal['total'] < 0) {
$arrErr['total'] = '合計額がマイナス表示にならないように調整して下さい。<br />';
if($arrVal['payment_total'] < 0) {
$arrErr['payment_total'] = 'お支払い合計額がマイナス表示にならないように調整して下さい。<br />';
if($arrVal['total_point'] < 0) {
$arrErr['use_point'] = '最終保持ポイントがマイナス表示にならないように調整して下さい。<br />';
$this->objFormParam->setParam($arrVal);
$this->objFormParam->setParam($arrData);
$this->objFormParam->convParam();
#if(count($this->arrErr) == 0) {
$this->arrErr = $this->lfCheek($arrInfo);
$arrRet = $this->objFormParam->getHashArray();
foreach($arrRet as $key => $val) {
$sqlval['update_date'] = 'Now()';
if (!empty($sqlval['deliv_date_year'])) {
$ts = mktime(0, 0, 0, $sqlval['deliv_date_month'], $sqlval['deliv_date_day'], $sqlval['deliv_date_year']);
$sqlval['deliv_date'] = date("y/m/d", $ts);
$arrWDAY = $masterData->getMasterData("mtb_wday");
$sqlval['deliv_date'] .= sprintf("(%s)", $arrWDAY[date("w", $ts)]);
$sqlval['deliv_date'] = "";
unset ($sqlval['deliv_date_year']);
unset ($sqlval['deliv_date_month']);
unset ($sqlval['deliv_date_day']);
unset ($sqlval['total_point']);
unset ($sqlval['commit_date']);
* XXX 本来なら配列だが, update 関数を string として
if (!isset ($addcol)) $addcol = "";
$objQuery->update("dtb_order", $sqlval, $where, array($order_id), $addcol);
$sql .= " payment_method = (SELECT payment_method FROM dtb_payment WHERE payment_id = ?)";
$sql .= " ,deliv_time = (SELECT deliv_time FROM dtb_delivtime WHERE time_id = ? AND deliv_id = (SELECT deliv_id FROM dtb_payment WHERE payment_id = ? ))";
if ($sqlval['status'] == ODERSTATUS_COMMIT) {
$sql .= " ,commit_date = NOW()";
$sql .= " WHERE order_id = ?";
if ($arrRet['deliv_time_id'] == "") {
$deliv_time_id = $arrRet['deliv_time_id'];
$arrUpdData = array($arrRet['payment_id'], $deliv_time_id, $arrRet['payment_id'], $order_id);
$objQuery->query($sql, $arrUpdData);
$arrDetail = $this->objFormParam->getSwapArray(array("product_id", "product_code", "product_name", "price", "quantity", "point_rate", "classcategory_id1", "classcategory_id2", "classcategory_name1", "classcategory_name2"));
// 変更しようとしている商品情報とDBに登録してある商品情報を比較することで、更新すべき数量を計算
$max = count($arrDetail);
for($i = 0; $i < $max; $i++ ) {
if (!empty($arrDetail[$i]['product_id'])) {
$arrPreDetail = $objQuery->select('*', "dtb_order_detail", "order_id = ? AND product_id = ? AND classcategory_id1 = ? AND classcategory_id2 = ?", array($order_id, $arrDetail[$i]['product_id'], $arrDetail[$i]['classcategory_id1'], $arrDetail[$i]['classcategory_id2']));
if (!empty($arrPreDetail) && $arrPreDetail[0]['quantity'] != $arrDetail[$i]['quantity']) {
$arrStockData[$k]['product_id'] = $arrDetail[$i]['product_id'];
$arrStockData[$k]['classcategory_id1'] = $arrDetail[$i]['classcategory_id1'];
$arrStockData[$k]['classcategory_id2'] = $arrDetail[$i]['classcategory_id2'];
$arrStockData[$k]['quantity'] = $arrPreDetail[0]['quantity'] - $arrDetail[$i]['quantity'];
} elseif (empty($arrPreDetail)) {
// 新しく追加された商品 もしくは 違う商品に変更された商品
$arrStockData[$k]['product_id'] = $arrDetail[$i]['product_id'];
$arrStockData[$k]['classcategory_id1'] = $arrDetail[$i]['classcategory_id1'];
$arrStockData[$k]['classcategory_id2'] = $arrDetail[$i]['classcategory_id2'];
$arrStockData[$k]['quantity'] = - $arrDetail[$i]['quantity'];
$objQuery->delete("dtb_order_detail", "order_id = ? AND product_id = ? AND classcategory_id1 = ? AND classcategory_id2 = ?", array($order_id, $arrDetail[$i]['product_id'], $arrDetail[$i]['classcategory_id1'], $arrDetail[$i]['classcategory_id2']));
// 上記の新しい商品のループでDELETEされなかった商品は、注文より削除された商品
$arrPreDetail = $objQuery->select('*', "dtb_order_detail", "order_id = ?", array($order_id));
foreach ($arrPreDetail AS $key=> $val) {
$arrStockData[$k]['product_id'] = $val['product_id'];
$arrStockData[$k]['classcategory_id1'] = $val['classcategory_id1'];
$arrStockData[$k]['classcategory_id2'] = $val['classcategory_id2'];
$arrStockData[$k]['quantity'] = $val['quantity'];
$objQuery->delete("dtb_order_detail", $where, array($order_id));
$max = count($arrDetail);
for($i = 0; $i < $max; $i++ ) {
$sqlval['order_id'] = $order_id;
$sqlval['product_id'] = $arrDetail[$i]['product_id'];
$sqlval['product_code'] = $arrDetail[$i]['product_code'];
$sqlval['product_name'] = $arrDetail[$i]['product_name'];
$sqlval['price'] = $arrDetail[$i]['price'];
$sqlval['quantity'] = $arrDetail[$i]['quantity'];
$sqlval['point_rate'] = $arrDetail[$i]['point_rate'];
$sqlval['classcategory_id1'] = $arrDetail[$i]['classcategory_id1'];
$sqlval['classcategory_id2'] = $arrDetail[$i]['classcategory_id2'];
$sqlval['classcategory_name1'] = $arrDetail[$i]['classcategory_name1'];
$sqlval['classcategory_name2'] = $arrDetail[$i]['classcategory_name2'];
$objQuery->insert("dtb_order_detail", $sqlval);
$status = $sqlval['status'];
if (ORDER_DELIV != $status && ORDER_CANCEL != $status) {
$stock_sql = "UPDATE dtb_products_class SET stock = stock + ? WHERE product_id = ? AND classcategory_id1 = ? AND classcategory_id2 = ?;";
foreach ($arrStockData AS $key=> $val) {
$stock_sqlval[] = $val['quantity'];
$stock_sqlval[] = $val['product_id'];
$stock_sqlval[] = $val['classcategory_id1'];
$stock_sqlval[] = $val['classcategory_id2'];
$objQuery->query($stock_sql, $stock_sqlval);
$arrRet = $this->objFormParam->getHashArray();
foreach($arrRet as $key => $val) {
// postgresqlとmysqlとで処理を分ける
if (DB_TYPE == "pgsql") {
$order_id = $objQuery->nextval("dtb_order","order_id");
}elseif (DB_TYPE == "mysql") {
$order_id = $objQuery->get_auto_increment("dtb_order");
$sqlval['order_id'] = $order_id;
$sqlval['create_date'] = "Now()";
// 注文ステータス:指定が無ければ新規受付に設定
if($sqlval["status"] == ""){
if($sqlval["customer_id"] == ""){
$sqlval['customer_id'] = '0';
if (!empty($sqlval['deliv_date_year'])) {
$ts = mktime(0, 0, 0, $sqlval['deliv_date_month'], $sqlval['deliv_date_day'], $sqlval['deliv_date_year']);
$sqlval['deliv_date'] = date("y/m/d", $ts);
$arrWDAY = $masterData->getMasterData("mtb_wday");
$sqlval['deliv_date'] .= sprintf("(%s)", $arrWDAY[date("w", $ts)]);
unset ($sqlval['deliv_date_year']);
unset ($sqlval['deliv_date_month']);
unset ($sqlval['deliv_date_day']);
unset ($sqlval['total_point']);
if ($sqlval['status'] == ODERSTATUS_COMMIT) {
$sqlval['commit_date'] = "Now()";
$objQuery->insert("dtb_order", $sqlval);
$sql .= " payment_method = (SELECT payment_method FROM dtb_payment WHERE payment_id = ?)";
$sql .= " ,deliv_time = (SELECT deliv_time FROM dtb_delivtime WHERE time_id = ? AND deliv_id = (SELECT deliv_id FROM dtb_payment WHERE payment_id = ? ))";
$sql .= " WHERE order_id = ?";
if ($arrRet['deliv_time_id'] == "") {
$deliv_time_id = $arrRet['deliv_time_id'];
$arrUpdData = array($arrRet['payment_id'], $deliv_time_id, $arrRet['payment_id'], $order_id);
$objQuery->query($sql, $arrUpdData);
$arrDetail = $this->objFormParam->getSwapArray(array("product_id", "product_code", "product_name", "price", "quantity", "point_rate", "classcategory_id1", "classcategory_id2", "classcategory_name1", "classcategory_name2"));
$objQuery->delete("dtb_order_detail", $where, array($order_id));
$max = count($arrDetail);
for($i = 0; $i < $max; $i++ ) {
$sqlval['order_id'] = $order_id;
$sqlval['product_id'] = $arrDetail[$i]['product_id'];
$sqlval['product_code'] = $arrDetail[$i]['product_code'];
$sqlval['product_name'] = $arrDetail[$i]['product_name'];
$sqlval['price'] = $arrDetail[$i]['price'];
$sqlval['quantity'] = $arrDetail[$i]['quantity'];
$sqlval['point_rate'] = $arrDetail[$i]['point_rate'];
$sqlval['classcategory_id1'] = $arrDetail[$i]['classcategory_id1'];
$sqlval['classcategory_id2'] = $arrDetail[$i]['classcategory_id2'];
$sqlval['classcategory_name1'] = $arrDetail[$i]['classcategory_name1'];
$sqlval['classcategory_name2'] = $arrDetail[$i]['classcategory_name2'];
$objQuery->insert("dtb_order_detail", $sqlval);
$pre_stock = $objQuery->getOne("SELECT stock FROM dtb_products_class WHERE product_id = ? AND classcategory_id1 = ? AND classcategory_id2 = ?", array($arrDetail[$i]['product_id'], $arrDetail[$i]['classcategory_id1'], $arrDetail[$i]['classcategory_id2']));
$stock_sqlval['stock'] = intval($pre_stock - $arrDetail[$i]['quantity']);
if ($stock_sqlval['stock'] === 0) {
$stock_sqlval['stock'] = '0';
$st_params[] = $arrDetail[$i]['product_id'];
$st_params[] = $arrDetail[$i]['classcategory_id1'];
$st_params[] = $arrDetail[$i]['classcategory_id2'];
$objQuery->update("dtb_products_class", $stock_sqlval, 'product_id = ? AND classcategory_id1 = ? AND classcategory_id2 = ?', $st_params);
function lfInsertProduct($product_id, $classcategory_id1, $classcategory_id2) {
$arrProduct = $this->lfGetProductsClass($product_id, $classcategory_id1, $classcategory_id2);
$this->arrForm = $this->objFormParam->getFormParamList();
if (!empty($this->arrForm['product_id']['value'])) {
foreach ($this->arrForm['product_id']['value'] AS $key=> $val) {
if ($val == $product_id && $this->arrForm['product_id']['classcategory_id1'][$key] == $classcategory_id1 && $this->arrForm['product_id']['classcategory_id2'][$key] == $classcategory_id2) {
++ $this->arrForm['quantity']['value'][$existes_key];
function lfUpdateProduct($product_id, $classcategory_id1, $classcategory_id2, $no) {
$arrProduct = $this->lfGetProductsClass($product_id, $classcategory_id1, $classcategory_id2);
$this->arrForm = $this->objFormParam->getFormParamList();
foreach ($arrProduct AS $key=> $val) {
if (!is_array($this->arrForm[$key]['value'])) {
unset ($this->arrForm[$key]['value']);
$this->arrForm[$key]['value'][] = $arrProduct[$key];
$this->arrForm[$key]['value'][$no] = $arrProduct[$key];
$objDb = new SC_Helper_DB_Ex();
$arrClassCatName = $objDb->sfGetIDValueList("dtb_classcategory", "classcategory_id", "name");
$arrRet = $objDb->sfGetProductsClass(array($product_id, $classcategory_id1, $classcategory_id2));
$arrProduct['price'] = $arrRet['price02'];
$arrProduct['quantity'] = 1;
$arrProduct['product_id'] = $arrRet['product_id'];
$arrProduct['point_rate'] = $arrRet['point_rate'];
$arrProduct['product_code'] = $arrRet['product_code'];
$arrProduct['product_name'] = $arrRet['name'];
$arrProduct['classcategory_id1'] = $arrRet['classcategory_id1'];
$arrProduct['classcategory_id2'] = $arrRet['classcategory_id2'];
$arrProduct['classcategory_name1'] = $arrClassCatName[$arrRet['classcategory_id1']];
$arrProduct['classcategory_name2'] = $arrClassCatName[$arrRet['classcategory_id2']];
* 検索結果から顧客IDを指定された場合、顧客情報をフォームに代入する
* @param int $edit_customer_id 顧客ID
// 顧客IDが指定されている場合のみ、処理を実行する
if( $edit_customer_id === "" ) return ;
// 検索で選択された顧客IDが入力されている場合
if( is_null($edit_customer_id) === false && 0 < strlen($edit_customer_id) && SC_Utils_Ex::sfIsInt($edit_customer_id) ){
$arrCustomerInfo = $objQuery->select('*', 'dtb_customer', 'customer_id = ? AND del_flg = 0', array($edit_customer_id));
// 顧客情報を取得する事が出来たら、テンプレートに値を渡す
if( 0 < count($arrCustomerInfo) && is_array($arrCustomerInfo) === true){
// カラム名にorder_を付ける(テンプレート側でorder_がついている為
foreach($arrCustomerInfo[0] as $index=> $customer_info){
// customer_idにはorder_を付けないようにする
$order_index = ($index == 'customer_id') ? $index : 'order_'. $index;
$arrCustomer[$order_index] = $customer_info;
$this->edit_customer_id = $edit_customer_id;
$create_date = $objQuery->getAll('SELECT now() as create_date;');
$arrCustomer['create_date'] = $create_date[0]['create_date'];
$this->objFormParam->setParam($arrCustomer);
$this->objFormParam->convParam();
Documentation generated on Fri, 24 Feb 2012 13:58:54 +0900 by Seasoft
|