You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

7039 lines
271 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<?php
define('IN_ASC', true);
require(dirname(__FILE__) . '/includes/init.php');
require_once(ROOT_PATH . 'includes/lib_order.php');
require_once(ROOT_PATH . 'includes/lib_goods.php');
// require_once(ROOT_PATH . 'includes/www_mb5_com_cn.php');
/*------------------------------------------------------ */
//-- 訂單查詢
/*------------------------------------------------------ */
if ($_REQUEST['act'] == 'order_query')
{
/* 檢查權限 */
admin_priv('order_view');
/* 載入配送方式 */
$smarty->assign('shipping_list', shipping_list());
/* 載入支付方式 */
$smarty->assign('pay_list', payment_list());
/* 載入國家 */
$smarty->assign('country_list', get_regions());
/* 載入訂單狀態、付款狀態、發貨狀態 */
$smarty->assign('os_list', get_status_list('order'));
$smarty->assign('ps_list', get_status_list('payment'));
$smarty->assign('ss_list', get_status_list('shipping'));
/* 模板賦值 */
$smarty->assign('ur_here', $_LANG['03_order_query']);
$smarty->assign('action_link', array('href' => 'order.php?act=list', 'text' => $_LANG['02_order_list']));
/* 顯示模板 */
assign_query_info();
$smarty->display('order_query.htm');
}
/*------------------------------------------------------ */
//-- 訂單列表
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'list')
{
/* 檢查權限 */
admin_priv('order_view');
/* 模板賦值 */
$smarty->assign('ur_here', $_LANG['02_order_list']);
$smarty->assign('action_link', array('href' => 'order.php?act=order_query', 'text' => $_LANG['03_order_query']));
$smarty->assign('status_list', $_LANG['cs']); // 訂單狀態
$smarty->assign('os_unconfirmed', OS_UNCONFIRMED);
$smarty->assign('cs_await_pay', CS_AWAIT_PAY);
$smarty->assign('cs_await_ship', CS_AWAIT_SHIP);
$smarty->assign('full_page', 1);
$order_list = order_list();
$smarty->assign('order_list', $order_list['orders']);
$smarty->assign('filter', $order_list['filter']);
$smarty->assign('record_count', $order_list['record_count']);
$smarty->assign('page_count', $order_list['page_count']);
$smarty->assign('sort_order_time', '<img src="images/sort_desc.gif">');
/* 顯示模板 */
assign_query_info();
$smarty->display('order_list.htm');
}
/*------------------------------------------------------ */
//-- 排序、分頁、查詢
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'query')
{
/* 檢查權限 */
admin_priv('order_view');
$order_list = order_list();
$smarty->assign('order_list', $order_list['orders']);
$smarty->assign('filter', $order_list['filter']);
$smarty->assign('record_count', $order_list['record_count']);
$smarty->assign('page_count', $order_list['page_count']);
$sort_flag = sort_flag($order_list['filter']);
$smarty->assign($sort_flag['tag'], $sort_flag['img']);
make_json_result($smarty->fetch('order_list.htm'), '', array('filter' => $order_list['filter'], 'page_count' => $order_list['page_count']));
}
/*------------------------------------------------------ */
//-- 訂單詳情頁面
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'info')
{
/* 根據訂單id或訂單號查詢訂單信息 */
if (isset($_REQUEST['order_id']))
{
$order_id = intval($_REQUEST['order_id']);
$order = order_info($order_id);
}
elseif (isset($_REQUEST['order_sn']))
{
$order_sn = trim($_REQUEST['order_sn']);
$order = order_info(0, $order_sn);
}
else
{
/* 如果參數不存在,退出 */
die('invalid parameter');
}
/* 如果訂單不存在,退出 */
if (empty($order))
{
die('order does not exist');
}
/* 根據訂單是否完成檢查權限 */
if (order_finished($order))
{
admin_priv('order_view_finished');
}
else
{
admin_priv('order_view');
}
/* 如果管理員屬於某個辦事處,檢查該訂單是否也屬於這個辦事處 */
$sql = "SELECT agency_id FROM " . $ecs->table('admin_user') . " WHERE user_id = '$_SESSION[admin_id]'";
$agency_id = $db->getOne($sql);
if ($agency_id > 0)
{
if ($order['agency_id'] != $agency_id)
{
sys_msg($_LANG['priv_error']);
}
}
//如果為預售活動則需要判斷預售活動是否已經成功結束了,如果未成功結束則不允許發貨
if($order['extension_code'] == PRE_SALE_CODE)
{
$pre_sale_id = $order['extension_id'];
$sql = "select is_finished from " . $ecs->table('goods_activity') . " where act_id = '" . $pre_sale_id . "'";
$is_finished = $db->getOne($sql);
if($is_finished == PSS_SUCCEED)
{
$smarty->assign('pre_sale_success', '1');
}
else
{
$smarty->assign('pre_sale_success', '0');
}
$smarty->assign('is_pre_sale', '1');
}
else
{
$smarty->assign('is_pre_sale', '0');
}
/* 取得上一個、下一個訂單號 */
if (!empty($_COOKIE['ECSCP']['lastfilter']))
{
$filter = unserialize(urldecode($_COOKIE['ECSCP']['lastfilter']));
if (!empty($filter['composite_status']))
{
$where = '';
//綜合狀態
switch($filter['composite_status'])
{
case CS_AWAIT_PAY :
$where .= order_query_sql('await_pay');
break;
case CS_AWAIT_SHIP :
$where .= order_query_sql('await_ship');
break;
case CS_FINISHED :
$where .= order_query_sql('finished');
break;
default:
if ($filter['composite_status'] != -1)
{
$where .= " AND o.order_status = '$filter[composite_status]' ";
}
}
}
}
$sql = "SELECT MAX(order_id) FROM " . $ecs->table('order_info') . " as o WHERE order_id < '$order[order_id]'";
if ($agency_id > 0)
{
$sql .= " AND agency_id = '$agency_id'";
}
if (!empty($where))
{
$sql .= $where;
}
$smarty->assign('prev_id', $db->getOne($sql));
$sql = "SELECT MIN(order_id) FROM " . $ecs->table('order_info') . " as o WHERE order_id > '$order[order_id]'";
if ($agency_id > 0)
{
$sql .= " AND agency_id = '$agency_id'";
}
if (!empty($where))
{
$sql .= $where;
}
$smarty->assign('next_id', $db->getOne($sql));
/* 取得用户名 */
if ($order['user_id'] > 0)
{
$user = user_info($order['user_id']);
if (!empty($user))
{
$order['user_name'] = $user['user_name'];
}
}
/* 取得所有辦事處 */
$sql = "SELECT agency_id, agency_name FROM " . $ecs->table('agency');
$smarty->assign('agency_list', $db->getAll($sql));
/* 取得區域名 */
// $sql = "SELECT concat(IFNULL(c.region_name, ''), ' ', IFNULL(p.region_name, ''), " .
// "' ', IFNULL(t.region_name, ''), ' ', IFNULL(d.region_name, '')) AS region " .
// "FROM " . $ecs->table('order_info') . " AS o " .
// "LEFT JOIN " . $ecs->table('region') . " AS c ON o.country = c.region_id " .
// "LEFT JOIN " . $ecs->table('region') . " AS p ON o.province = p.region_id " .
// "LEFT JOIN " . $ecs->table('region') . " AS t ON o.city = t.region_id " .
// "LEFT JOIN " . $ecs->table('region') . " AS d ON o.district = d.region_id " .
// "WHERE o.order_id = '$order[order_id]'";
$order['region'] = '';
/* 格式化金額 */
if ($order['order_amount'] < 0)
{
$order['money_refund'] = abs($order['order_amount']);
$order['formated_money_refund'] = price_format(abs($order['order_amount']));
}
/* 其他處理 */
$order['order_time'] = local_date($_CFG['time_format'], $order['add_time']);
$order['pay_time'] = $order['pay_time'] > 0 ?
local_date($_CFG['time_format'], $order['pay_time']) : $_LANG['ps'][PS_UNPAYED];
$order['shipping_time'] = $order['shipping_time'] > 0 ?
local_date($_CFG['time_format'], $order['shipping_time']) : $_LANG['ss'][SS_UNSHIPPED];
$order['status'] = $_LANG['os'][$order['order_status']] . ',' . $_LANG['ps'][$order['pay_status']] . ',' . $_LANG['ss'][$order['shipping_status']];
$order['invoiceno'] = $order['invoice_no'];
$order['invoice_no'] = $order['shipping_status'] == SS_UNSHIPPED || $order['shipping_status'] == SS_PREPARING ? $_LANG['ss'][SS_UNSHIPPED] : $order['invoice_no'];
/* 取得訂單的來源 */
if ($order['from_ad'] == 0)
{
$order['referer'] = empty($order['referer']) ? $_LANG['from_self_site'] : $order['referer'];
}
elseif ($order['from_ad'] == -1)
{
$order['referer'] = $_LANG['from_goods_js'] . ' ('.$_LANG['from'] . $order['referer'].')';
}
else
{
/* 查詢廣告的名稱 */
$ad_name = $db->getOne("SELECT ad_name FROM " .$ecs->table('ad'). " WHERE ad_id='$order[from_ad]'");
$order['referer'] = $_LANG['from_ad_js'] . $ad_name . ' ('.$_LANG['from'] . $order['referer'].')';
}
/* 此訂單的發貨備註(此訂單的最後一條操作記錄) */
$sql = "SELECT action_note FROM " . $ecs->table('order_action').
" WHERE order_id = '$order[order_id]' AND shipping_status = 1 ORDER BY log_time DESC";
$order['invoice_note'] = $db->getOne($sql);
/* 取得訂單產品總重量 */
$weight_price = order_weight_price($order['order_id']);
$order['total_weight'] = $weight_price['formated_weight'];
/* 物流跟蹤--開始 模板之家開發www。mb5.com.cn */
if($order['shipping_id']!=-1 && $order['invoiceno'] && $order['shipping_name']){
$shipping = get_shipping_object($order['shipping_id']);
$result = $shipping->getorder($order['invoice_no']);
$kuaidi_list['data'] = $result['data'];
$kuaidi_list['shipping_name'] = $order['shipping_name'];
$kuaidi_list['invoice_no'] = $order['invoice_no'];
$smarty->assign('kuaidi_list', $kuaidi_list);
}
/* 物流跟蹤--開始 模板之家開發www·mb5·com·cn */
/* 參數賦值:訂單 */
$smarty->assign('order', $order);
/* 取得用户信息 */
if ($order['user_id'] > 0)
{
/* 用户等級 */
if ($user['user_rank'] > 0)
{
$where = " WHERE rank_id = '$user[user_rank]' ";
}
else
{
$where = " WHERE min_points <= " . intval($user['rank_points']) . " ORDER BY min_points DESC ";
}
$sql = "SELECT rank_name FROM " . $ecs->table('user_rank') . $where;
$user['rank_name'] = $db->getOne($sql);
// 用户紅包數量
$day = getdate();
$today = local_mktime(23, 59, 59, $day['mon'], $day['mday'], $day['year']);
$sql = "SELECT COUNT(*) " .
"FROM " . $ecs->table('bonus_type') . " AS bt, " . $ecs->table('user_bonus') . " AS ub " .
"WHERE bt.type_id = ub.bonus_type_id " .
"AND ub.user_id = '$order[user_id]' " .
"AND ub.order_id = 0 " .
"AND bt.use_start_date <= '$today' " .
"AND bt.use_end_date >= '$today'";
$user['bonus_count'] = $db->getOne($sql);
$smarty->assign('user', $user);
// 地址信息
$sql = "SELECT * FROM " . $ecs->table('user_address') . " WHERE user_id = '$order[user_id]'";
$smarty->assign('address_list', $db->getAll($sql));
}
/* 取得訂單產品及貨品 */
$goods_list = array();
$goods_attr = array();
$sql = "SELECT o.*, IF(o.product_id > 0, p.product_number, g.goods_number) AS storage, o.goods_attr, g.suppliers_id, IFNULL(b.brand_name, '') AS brand_name, p.product_sn
FROM " . $ecs->table('order_goods') . " AS o
LEFT JOIN " . $ecs->table('products') . " AS p
ON p.product_id = o.product_id
LEFT JOIN " . $ecs->table('goods') . " AS g
ON o.goods_id = g.goods_id
LEFT JOIN " . $ecs->table('brand') . " AS b
ON g.brand_id = b.brand_id
WHERE o.order_id = '$order[order_id]'";
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
/* 虛擬產品支持 */
if ($row['is_real'] == 0)
{
/* 取得語言項 */
$filename = ROOT_PATH . 'plugins/' . $row['extension_code'] . '/languages/common_' . $_CFG['lang'] . '.php';
if (file_exists($filename))
{
include_once($filename);
if (!empty($_LANG[$row['extension_code'].'_link']))
{
$row['goods_name'] = $row['goods_name'] . sprintf($_LANG[$row['extension_code'].'_link'], $row['goods_id'], $order['order_sn']);
}
}
}
$row['formated_subtotal'] = price_format($row['goods_price'] * $row['goods_number']);
$row['formated_goods_price'] = price_format($row['goods_price']);
$goods_attr[] = explode(' ', trim($row['goods_attr'])); //將產品屬性拆分為一個數組
if ($row['extension_code'] == 'package_buy')
{
$row['storage'] = '';
$row['brand_name'] = '';
$row['package_goods_list'] = get_package_goods($row['goods_id']);
}
$goods_list[] = $row;
}
$attr = array();
$arr = array();
foreach ($goods_attr AS $index => $array_val)
{
foreach ($array_val AS $value)
{
$arr = explode(':', $value);//以 : 號將屬性拆開
$attr[$index][] = @array('name' => $arr[0], 'value' => $arr[1]);
}
}
$smarty->assign('goods_attr', $attr);
$smarty->assign('goods_list', $goods_list);
/* 取得能執行的操作列表 */
$operable_list = operable_list($order);
$smarty->assign('operable_list', $operable_list);
/* 取得訂單操作記錄 */
$act_list = array();
$sql = "SELECT * FROM " . $ecs->table('order_action') . " WHERE order_id = '$order[order_id]' ORDER BY log_time DESC,action_id DESC";
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
$row['order_status'] = $_LANG['os'][$row['order_status']];
$row['pay_status'] = $_LANG['ps'][$row['pay_status']];
$row['shipping_status'] = $_LANG['ss'][$row['shipping_status']];
$row['action_time'] = local_date($_CFG['time_format'], $row['log_time']);
$act_list[] = $row;
}
$smarty->assign('action_list', $act_list);
/* 取得是否存在實體產品 */
$smarty->assign('exist_real_goods', exist_real_goods($order['order_id']));
/* 是否打印訂單,分別賦值 */
if (isset($_GET['print']))
{
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('shop_url', $ecs->url());
$smarty->assign('shop_address', $_CFG['shop_address']);
$smarty->assign('service_phone',$_CFG['service_phone']);
$smarty->assign('print_time', local_date($_CFG['time_format']));
$smarty->assign('action_user', $_SESSION['admin_name']);
$smarty->template_dir = '../' . DATA_DIR;
$smarty->display('order_print.html');
}
/* 打印快遞單 */
elseif (isset($_GET['shipping_print']))
{
//$smarty->assign('print_time', local_date($_CFG['time_format']));
//發貨地址所在地
$region_array = array();
$region_id = !empty($_CFG['shop_country']) ? $_CFG['shop_country'] . ',' : '';
$region_id .= !empty($_CFG['shop_province']) ? $_CFG['shop_province'] . ',' : '';
$region_id .= !empty($_CFG['shop_city']) ? $_CFG['shop_city'] . ',' : '';
$region_id .= !empty($order['province']) ? $order['province'] . ',' : '';$region_id .= !empty($order['city']) ? $order['city'] . ',' : '';$region_id .= !empty($order['district']) ? $order['district'] . ',' : '';
$region_id = substr($region_id, 0, -1);
$region = $db->getAll("SELECT region_id, region_name FROM " . $ecs->table("region") . " WHERE region_id IN ($region_id)");
if (!empty($region))
{
foreach($region as $region_data)
{
$region_array[$region_data['region_id']] = $region_data['region_name'];
}
}
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('order_id', $order_id);
$smarty->assign('province', $region_array[$_CFG['shop_province']]);
$smarty->assign('city', $region_array[$_CFG['shop_city']]);
$smarty->assign('shop_address', $_CFG['shop_address']);
$smarty->assign('service_phone',$_CFG['service_phone']);
$shipping = $db->getRow("SELECT * FROM " . $ecs->table("shipping") . " WHERE shipping_id = " . $order['shipping_id']);
//打印單模式
if ($shipping['print_model'] == 2)
{
/* 可視化 */
/* 快遞單 */
$shipping['print_bg'] = empty($shipping['print_bg']) ? '' : get_site_root_url() . $shipping['print_bg'];
/* 取快遞單背景寬高 */
if (!empty($shipping['print_bg']))
{
$_size = @getimagesize($shipping['print_bg']);
if ($_size != false)
{
$shipping['print_bg_size'] = array('width' => $_size[0], 'height' => $_size[1]);
}
}
if (empty($shipping['print_bg_size']))
{
$shipping['print_bg_size'] = array('width' => '1024', 'height' => '600');
}
/* 標籤信息 */
$lable_box = array();
$lable_box['t_shop_country'] = $region_array[$_CFG['shop_country']]; //網店-國家
$lable_box['t_shop_city'] = $region_array[$_CFG['shop_city']]; //網店-城市
$lable_box['t_shop_province'] = $region_array[$_CFG['shop_province']]; //網店-省份
$lable_box['t_shop_name'] = $_CFG['shop_name']; //網店-名稱
$lable_box['t_shop_district'] = ''; //網店-區/縣
$lable_box['t_shop_tel'] = $_CFG['service_phone']; //網店-聯繫電話
$lable_box['t_shop_address'] = $_CFG['shop_address']; //網店-地址
$lable_box['t_customer_country'] = $region_array[$order['country']]; //收件人-國家
$lable_box['t_customer_province'] = $region_array[$order['province']]; //收件人-省份
$lable_box['t_customer_city'] = $region_array[$order['city']]; //收件人-城市
$lable_box['t_customer_district'] = $region_array[$order['district']]; //收件人-區/縣
$lable_box['t_customer_tel'] = $order['tel']; //收件人-電話
$lable_box['t_customer_mobel'] = $order['mobile']; //收件人-手機
$lable_box['t_customer_post'] = $order['zipcode']; //收件人-郵編
$lable_box['t_customer_address'] = $order['address']; //收件人-詳細地址
$lable_box['t_customer_name'] = $order['consignee']; //收件人-姓名
$gmtime_utc_temp = gmtime(); //獲取 UTC 時間戳
$lable_box['t_year'] = date('Y', $gmtime_utc_temp); //年-當日日期
$lable_box['t_months'] = date('m', $gmtime_utc_temp); //月-當日日期
$lable_box['t_day'] = date('d', $gmtime_utc_temp); //日-當日日期
$lable_box['t_order_no'] = $order['order_sn']; //訂單號-訂單
$lable_box['t_order_postscript'] = $order['postscript']; //備註-訂單
$lable_box['t_order_best_time'] = $order['best_time']; //送貨時間-訂單
$lable_box['t_pigeon'] = '√'; //√-對號
$lable_box['t_custom_content'] = ''; //自定義內容
//標籤替換
$temp_config_lable = explode('||,||', $shipping['config_lable']);
if (!is_array($temp_config_lable))
{
$temp_config_lable[] = $shipping['config_lable'];
}
foreach ($temp_config_lable as $temp_key => $temp_lable)
{
$temp_info = explode(',', $temp_lable);
if (is_array($temp_info))
{
$temp_info[1] = $lable_box[$temp_info[0]];
}
$temp_config_lable[$temp_key] = implode(',', $temp_info);
}
$shipping['config_lable'] = implode('||,||', $temp_config_lable);
$smarty->assign('shipping', $shipping);
$smarty->display('print.htm');
}
elseif (!empty($shipping['shipping_print']))
{
/* 代碼 */
echo $smarty->fetch("str:" . $shipping['shipping_print']);
}
else
{
$shipping_code = $db->getOne("SELECT shipping_code FROM " . $ecs->table('shipping') . " WHERE shipping_id=" . $order['shipping_id']);
if ($shipping_code)
{
include_once(ROOT_PATH . 'includes/modules/shipping/' . $shipping_code . '.php');
}
if (!empty($_LANG['shipping_print']))
{
echo $smarty->fetch("str:$_LANG[shipping_print]");
}
else
{
echo $_LANG['no_print_shipping'];
}
}
}
else
{
/* 模板賦值 */
$smarty->assign('ur_here', $_LANG['order_info']);
$smarty->assign('action_link', array('href' => 'order.php?act=list&' . list_link_postfix(), 'text' => $_LANG['02_order_list']));
/* 顯示模板 */
assign_query_info();
$smarty->display('order_info.htm');
}
}
/*------------------------------------------------------ */
//-- 發貨單列表
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'delivery_list')
{
/* 檢查權限 */
admin_priv('delivery_view');
/* 查詢 */
$result = delivery_list();
/* 模板賦值 */
$smarty->assign('ur_here', $_LANG['09_delivery_order']);
$smarty->assign('os_unconfirmed', OS_UNCONFIRMED);
$smarty->assign('cs_await_pay', CS_AWAIT_PAY);
$smarty->assign('cs_await_ship', CS_AWAIT_SHIP);
$smarty->assign('full_page', 1);
$smarty->assign('delivery_list', $result['delivery']);
$smarty->assign('filter', $result['filter']);
$smarty->assign('record_count', $result['record_count']);
$smarty->assign('page_count', $result['page_count']);
$smarty->assign('sort_update_time', '<img src="images/sort_desc.gif">');
/* 顯示模板 */
assign_query_info();
$smarty->display('delivery_list.htm');
}
/*------------------------------------------------------ */
//-- 搜索、排序、分頁
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'delivery_query')
{
/* 檢查權限 */
admin_priv('delivery_view');
$result = delivery_list();
$smarty->assign('delivery_list', $result['delivery']);
$smarty->assign('filter', $result['filter']);
$smarty->assign('record_count', $result['record_count']);
$smarty->assign('page_count', $result['page_count']);
$sort_flag = sort_flag($result['filter']);
$smarty->assign($sort_flag['tag'], $sort_flag['img']);
make_json_result($smarty->fetch('delivery_list.htm'), '', array('filter' => $result['filter'], 'page_count' => $result['page_count']));
}
/*------------------------------------------------------ */
//-- 發貨單詳細
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'delivery_info')
{
/* 檢查權限 */
admin_priv('delivery_view');
$delivery_id = intval(trim($_REQUEST['delivery_id']));
/* 根據發貨單id查詢發貨單信息 */
if (!empty($delivery_id))
{
$delivery_order = delivery_order_info($delivery_id);
}
else
{
die('order does not exist');
}
/* 如果管理員屬於某個辦事處,檢查該訂單是否也屬於這個辦事處 */
$sql = "SELECT agency_id FROM " . $ecs->table('admin_user') . " WHERE user_id = '" . $_SESSION['admin_id'] . "'";
$agency_id = $db->getOne($sql);
if ($agency_id > 0)
{
if ($delivery_order['agency_id'] != $agency_id)
{
sys_msg($_LANG['priv_error']);
}
/* 取當前辦事處信息 */
$sql = "SELECT agency_name FROM " . $ecs->table('agency') . " WHERE agency_id = '$agency_id' LIMIT 0, 1";
$agency_name = $db->getOne($sql);
$delivery_order['agency_name'] = $agency_name;
}
/* 取得用户名 */
if ($delivery_order['user_id'] > 0)
{
$user = user_info($delivery_order['user_id']);
if (!empty($user))
{
$delivery_order['user_name'] = $user['user_name'];
}
}
/* 取得區域名 */
$sql = "SELECT concat(IFNULL(c.region_name, ''), ' ', IFNULL(p.region_name, ''), " .
"' ', IFNULL(t.region_name, ''), ' ', IFNULL(d.region_name, '')) AS region " .
"FROM " . $ecs->table('order_info') . " AS o " .
"LEFT JOIN " . $ecs->table('region') . " AS c ON o.country = c.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS p ON o.province = p.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS t ON o.city = t.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS d ON o.district = d.region_id " .
"WHERE o.order_id = '" . $delivery_order['order_id'] . "'";
$delivery_order['region'] = $db->getOne($sql);
/* 是否保價 */
$order['insure_yn'] = empty($order['insure_fee']) ? 0 : 1;
/* 取得發貨單產品 */
$goods_sql = "SELECT *
FROM " . $ecs->table('delivery_goods') . "
WHERE delivery_id = " . $delivery_order['delivery_id'];
$goods_list = $GLOBALS['db']->getAll($goods_sql);
/* 是否存在實體產品 */
$exist_real_goods = 0;
if ($goods_list)
{
foreach ($goods_list as $value)
{
if ($value['is_real'])
{
$exist_real_goods++;
}
}
}
/* 取得訂單操作記錄 */
$act_list = array();
$sql = "SELECT * FROM " . $ecs->table('order_action') . " WHERE order_id = '" . $delivery_order['order_id'] . "' AND action_place = 1 ORDER BY log_time DESC,action_id DESC";
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
$row['order_status'] = $_LANG['os'][$row['order_status']];
$row['pay_status'] = $_LANG['ps'][$row['pay_status']];
$row['shipping_status'] = ($row['shipping_status'] == SS_SHIPPED_ING) ? $_LANG['ss_admin'][SS_SHIPPED_ING] : $_LANG['ss'][$row['shipping_status']];
$row['action_time'] = local_date($_CFG['time_format'], $row['log_time']);
$act_list[] = $row;
}
$smarty->assign('action_list', $act_list);
/* 模板賦值 */
$smarty->assign('delivery_order', $delivery_order);
$smarty->assign('exist_real_goods', $exist_real_goods);
$smarty->assign('goods_list', $goods_list);
$smarty->assign('delivery_id', $delivery_id); // 發貨單id
/* 顯示模板 */
$smarty->assign('ur_here', $_LANG['delivery_operate'] . $_LANG['detail']);
$smarty->assign('action_link', array('href' => 'order.php?act=delivery_list&' . list_link_postfix(), 'text' => $_LANG['09_delivery_order']));
$smarty->assign('action_act', ($delivery_order['status'] == 2) ? 'delivery_ship' : 'delivery_cancel_ship');
assign_query_info();
$smarty->display('delivery_info.htm');
exit; //
}
/*------------------------------------------------------ */
//-- 發貨單發貨確認
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'delivery_ship')
{
/* 檢查權限 */
admin_priv('delivery_view');
/* 定義當前時間 */
define('GMTIME_UTC', gmtime()); // 獲取 UTC 時間戳
/* 取得參數 */
$delivery = array();
$order_id = intval(trim($_REQUEST['order_id'])); // 訂單id
$delivery_id = intval(trim($_REQUEST['delivery_id'])); // 發貨單id
$delivery['invoice_no'] = isset($_REQUEST['invoice_no']) ? trim($_REQUEST['invoice_no']) : '';
$action_note = isset($_REQUEST['action_note']) ? trim($_REQUEST['action_note']) : '';
/* 根據發貨單id查詢發貨單信息 */
if (!empty($delivery_id))
{
$delivery_order = delivery_order_info($delivery_id);
}
else
{
die('order does not exist');
}
/* 查詢訂單信息 */
$order = order_info($order_id);
/* 檢查此單發貨產品庫存缺貨情況 */
$virtual_goods = array();
$delivery_stock_sql = "SELECT DG.goods_id, DG.is_real, DG.product_id, SUM(DG.send_number) AS sums, IF(DG.product_id > 0, P.product_number, G.goods_number) AS storage, G.goods_name, DG.send_number
FROM " . $GLOBALS['ecs']->table('delivery_goods') . " AS DG, " . $GLOBALS['ecs']->table('goods') . " AS G, " . $GLOBALS['ecs']->table('products') . " AS P
WHERE DG.goods_id = G.goods_id
AND DG.delivery_id = '$delivery_id'
AND DG.product_id = P.product_id
GROUP BY DG.product_id ";
$delivery_stock_result = $GLOBALS['db']->getAll($delivery_stock_sql);
/* 如果產品存在規格就查詢規格,如果不存在規格按產品庫存查詢 */
if(!empty($delivery_stock_result))
{
foreach ($delivery_stock_result as $value)
{
if (($value['sums'] > $value['storage'] || $value['storage'] <= 0) && (($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP) || ($_CFG['use_storage'] == '0' && $value['is_real'] == 0)))
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=delivery_info&delivery_id=' . $delivery_id);
sys_msg(sprintf($_LANG['act_good_vacancy'], $value['goods_name']), 1, $links);
break;
}
/* 虛擬產品列表 virtual_card*/
if ($value['is_real'] == 0)
{
$virtual_goods[] = array(
'goods_id' => $value['goods_id'],
'goods_name' => $value['goods_name'],
'num' => $value['send_number']
);
}
}
}
else
{
$delivery_stock_sql = "SELECT DG.goods_id, DG.is_real, SUM(DG.send_number) AS sums, G.goods_number, G.goods_name, DG.send_number
FROM " . $GLOBALS['ecs']->table('delivery_goods') . " AS DG, " . $GLOBALS['ecs']->table('goods') . " AS G
WHERE DG.goods_id = G.goods_id
AND DG.delivery_id = '$delivery_id'
GROUP BY DG.goods_id ";
$delivery_stock_result = $GLOBALS['db']->getAll($delivery_stock_sql);
foreach ($delivery_stock_result as $value)
{
if (($value['sums'] > $value['goods_number'] || $value['goods_number'] <= 0) && (($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP) || ($_CFG['use_storage'] == '0' && $value['is_real'] == 0)))
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=delivery_info&delivery_id=' . $delivery_id);
sys_msg(sprintf($_LANG['act_good_vacancy'], $value['goods_name']), 1, $links);
break;
}
/* 虛擬產品列表 virtual_card*/
if ($value['is_real'] == 0)
{
$virtual_goods[] = array(
'goods_id' => $value['goods_id'],
'goods_name' => $value['goods_name'],
'num' => $value['send_number']
);
}
}
}
/* 發貨 */
/* 處理虛擬卡 產品(虛貨) */
if (is_array($virtual_goods) && count($virtual_goods) > 0)
{
foreach ($virtual_goods as $virtual_value)
{
virtual_card_shipping($virtual_value,$order['order_sn'], $msg, 'split');
}
}
/* 如果使用庫存,且發貨時減庫存,則修改庫存 */
if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP)
{
foreach ($delivery_stock_result as $value)
{
/* 產品(實貨)、超級禮包(實貨) */
if ($value['is_real'] != 0)
{
//(貨品)
if (!empty($value['product_id']))
{
$minus_stock_sql = "UPDATE " . $GLOBALS['ecs']->table('products') . "
SET product_number = product_number - " . $value['sums'] . "
WHERE product_id = " . $value['product_id'];
$GLOBALS['db']->query($minus_stock_sql, 'SILENT');
}
$minus_stock_sql = "UPDATE " . $GLOBALS['ecs']->table('goods') . "
SET goods_number = goods_number - " . $value['sums'] . "
WHERE goods_id = " . $value['goods_id'];
$GLOBALS['db']->query($minus_stock_sql, 'SILENT');
}
}
}
/* 修改發貨單信息 */
$invoice_no = str_replace(',', '<br>', $delivery['invoice_no']);
$invoice_no = trim($invoice_no, '<br>');
$_delivery['invoice_no'] = $invoice_no;
$_delivery['status'] = 0; // 0為已發貨
$query = $db->autoExecute($ecs->table('delivery_order'), $_delivery, 'UPDATE', "delivery_id = $delivery_id", 'SILENT');
if (!$query)
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['delivery_sn'] . $_LANG['detail'], 'href' => 'order.php?act=delivery_info&delivery_id=' . $delivery_id);
sys_msg($_LANG['act_false'], 1, $links);
}
/* 標記訂單為已確認 “已發貨” */
/* 更新發貨時間 */
$order_finish = get_all_delivery_finish($order_id);
$shipping_status = ($order_finish == 1) ? SS_SHIPPED : SS_SHIPPED_PART;
$arr['shipping_status'] = $shipping_status;
$arr['shipping_time'] = GMTIME_UTC; // 發貨時間
$arr['invoice_no'] = trim($order['invoice_no'] . '<br>' . $invoice_no, '<br>');
update_order($order_id, $arr);
/* 發貨單發貨記錄log */
order_action($order['order_sn'], OS_CONFIRMED, $shipping_status, $order['pay_status'], $action_note, null, 1);
/* 如果當前訂單已經全部發貨 */
if ($order_finish)
{
/* 如果訂單用户不為空,計算積分,併發給用户;發紅包 */
if ($order['user_id'] > 0)
{
/* 取得用户信息 */
$user = user_info($order['user_id']);
/* 計算併發放積分 */
$integral = integral_to_give($order);
log_account_change($order['user_id'], 0, 0, intval($integral['rank_points']), intval($integral['custom_points']), sprintf($_LANG['order_gift_integral'], $order['order_sn']));
/* 發放紅包 */
send_order_bonus($order_id);
}
/* 發送郵件 */
$cfg = $_CFG['send_ship_email'];
if ($cfg == '1')
{
$order['invoice_no'] = $invoice_no;
$tpl = get_mail_template('deliver_notice');
$smarty->assign('order', $order);
$smarty->assign('send_time', local_date($_CFG['time_format']));
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('send_date', local_date($_CFG['date_format']));
$smarty->assign('sent_date', local_date($_CFG['date_format']));
$smarty->assign('confirm_url', $ecs->url() . 'receive.php?id=' . $order['order_id'] . '&con=' . rawurlencode($order['consignee']));
$smarty->assign('send_msg_url',$ecs->url() . 'user.php?act=message_list&order_id=' . $order['order_id']);
$content = $smarty->fetch('str:' . $tpl['template_content']);
if (!send_mail($order['consignee'], $order['email'], $tpl['template_subject'], $content, $tpl['is_html']))
{
$msg = $_LANG['send_mail_fail'];
}
}
/* 商家發貨時給客户發送短信提醒 */
if ($_CFG['ecsdxt_order_shipped'] == '1' && $order['mobile'] != '')
{
require_once(ROOT_PATH . 'includes/lib_sms.php');
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('order_sn', $order['order_sn']);
$smarty->assign('time', local_date($GLOBALS['_LANG']['sms_time_format']));
$content = $smarty->fetch('str:' . $_CFG['ecsdxt_order_shipped_value']);
$ret = sendsms($order['mobile'], $content);
}
/* 微信發送發貨通知*/
$wxch_order_name = 'order';
$sql ="select autoload from ". $GLOBALS['ecs']->table('weixin_order') ." where order_name='order'";
$autoload=$db->getOne($sql);
if($autoload=="yes"){
include_once(ROOT_PATH . 'mobile/wxch_notice.php');
weixin_notice($order,'order');
}
}
/* 清除緩存 */
clear_cache_files();
/* 操作成功 */
$links[] = array('text' => $_LANG['09_delivery_order'], 'href' => 'order.php?act=delivery_list');
$links[] = array('text' => $_LANG['delivery_sn'] . $_LANG['detail'], 'href' => 'order.php?act=delivery_info&delivery_id=' . $delivery_id);
sys_msg($_LANG['act_ok'], 0, $links);
}
/*------------------------------------------------------ */
//-- 發貨單取消發貨
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'delivery_cancel_ship')
{
/* 檢查權限 */
admin_priv('delivery_view');
/* 取得參數 */
$delivery = '';
$order_id = intval(trim($_REQUEST['order_id'])); // 訂單id
$delivery_id = intval(trim($_REQUEST['delivery_id'])); // 發貨單id
$delivery['invoice_no'] = isset($_REQUEST['invoice_no']) ? trim($_REQUEST['invoice_no']) : '';
$action_note = isset($_REQUEST['action_note']) ? trim($_REQUEST['action_note']) : '';
/* 根據發貨單id查詢發貨單信息 */
if (!empty($delivery_id))
{
$delivery_order = delivery_order_info($delivery_id);
}
else
{
die('order does not exist');
}
/* 查詢訂單信息 */
$order = order_info($order_id);
/* 取消當前發貨單物流單號 */
$_delivery['invoice_no'] = '';
$_delivery['status'] = 2;
$query = $db->autoExecute($ecs->table('delivery_order'), $_delivery, 'UPDATE', "delivery_id = $delivery_id", 'SILENT');
if (!$query)
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['delivery_sn'] . $_LANG['detail'], 'href' => 'order.php?act=delivery_info&delivery_id=' . $delivery_id);
sys_msg($_LANG['act_false'], 1, $links);
exit;
}
/* 修改定單發貨單號 */
$invoice_no_order = explode('<br>', $order['invoice_no']);
$invoice_no_delivery = explode('<br>', $delivery_order['invoice_no']);
foreach ($invoice_no_order as $key => $value)
{
$delivery_key = array_search($value, $invoice_no_delivery);
if ($delivery_key !== false)
{
unset($invoice_no_order[$key], $invoice_no_delivery[$delivery_key]);
if (count($invoice_no_delivery) == 0)
{
break;
}
}
}
$_order['invoice_no'] = implode('<br>', $invoice_no_order);
/* 更新配送狀態 */
$order_finish = get_all_delivery_finish($order_id);
$shipping_status = ($order_finish == -1) ? SS_SHIPPED_PART : SS_SHIPPED_ING;
$arr['shipping_status'] = $shipping_status;
if ($shipping_status == SS_SHIPPED_ING)
{
$arr['shipping_time'] = ''; // 發貨時間
}
$arr['invoice_no'] = $_order['invoice_no'];
update_order($order_id, $arr);
/* 發貨單取消發貨記錄log */
order_action($order['order_sn'], $order['order_status'], $shipping_status, $order['pay_status'], $action_note, null, 1);
/* 如果使用庫存,則增加庫存 */
if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP)
{
// 檢查此單發貨產品數量
$virtual_goods = array();
$delivery_stock_sql = "SELECT DG.goods_id, DG.product_id, DG.is_real, SUM(DG.send_number) AS sums
FROM " . $GLOBALS['ecs']->table('delivery_goods') . " AS DG
WHERE DG.delivery_id = '$delivery_id'
GROUP BY DG.goods_id ";
$delivery_stock_result = $GLOBALS['db']->getAll($delivery_stock_sql);
foreach ($delivery_stock_result as $key => $value)
{
/* 虛擬產品 */
if ($value['is_real'] == 0)
{
continue;
}
//(貨品)
if (!empty($value['product_id']))
{
$minus_stock_sql = "UPDATE " . $GLOBALS['ecs']->table('products') . "
SET product_number = product_number + " . $value['sums'] . "
WHERE product_id = " . $value['product_id'];
$GLOBALS['db']->query($minus_stock_sql, 'SILENT');
}
$minus_stock_sql = "UPDATE " . $GLOBALS['ecs']->table('goods') . "
SET goods_number = goods_number + " . $value['sums'] . "
WHERE goods_id = " . $value['goods_id'];
$GLOBALS['db']->query($minus_stock_sql, 'SILENT');
}
}
/* 發貨單全退回時,退回其它 */
if ($order['order_status'] == SS_SHIPPED_ING)
{
/* 如果訂單用户不為空,計算積分,並退回 */
if ($order['user_id'] > 0)
{
/* 取得用户信息 */
$user = user_info($order['user_id']);
/* 計算並退回積分 */
$integral = integral_to_give($order);
log_account_change($order['user_id'], 0, 0, (-1) * intval($integral['rank_points']), (-1) * intval($integral['custom_points']), sprintf($_LANG['return_order_gift_integral'], $order['order_sn']));
/* todo 計算並退回紅包 */
return_order_bonus($order_id);
}
}
/* 清除緩存 */
clear_cache_files();
/* 操作成功 */
$links[] = array('text' => $_LANG['delivery_sn'] . $_LANG['detail'], 'href' => 'order.php?act=delivery_info&delivery_id=' . $delivery_id);
sys_msg($_LANG['act_ok'], 0, $links);
}
/*------------------------------------------------------ */
//-- 退貨單列表
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'back_list')
{
/* 檢查權限 */
admin_priv('back_view');
/* 查詢 */
$result = back_list();
/* 模板賦值 */
$smarty->assign('ur_here', $_LANG['10_back_order']);
$smarty->assign('os_unconfirmed', OS_UNCONFIRMED);
$smarty->assign('cs_await_pay', CS_AWAIT_PAY);
$smarty->assign('cs_await_ship', CS_AWAIT_SHIP);
$smarty->assign('full_page', 1);
$smarty->assign('back_list', $result['back']);
$smarty->assign('filter', $result['filter']);
$smarty->assign('record_count', $result['record_count']);
$smarty->assign('page_count', $result['page_count']);
$smarty->assign('sort_update_time', '<img src="images/sort_desc.gif">');
/* 顯示模板 */
assign_query_info();
$smarty->display('back_list.htm');
}
/*------------------------------------------------------ */
//-- 搜索、排序、分頁
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'back_query')
{
/* 檢查權限 */
admin_priv('back_view');
$result = back_list();
$smarty->assign('back_list', $result['back']);
$smarty->assign('filter', $result['filter']);
$smarty->assign('record_count', $result['record_count']);
$smarty->assign('page_count', $result['page_count']);
$sort_flag = sort_flag($result['filter']);
$smarty->assign($sort_flag['tag'], $sort_flag['img']);
make_json_result($smarty->fetch('back_list.htm'), '', array('filter' => $result['filter'], 'page_count' => $result['page_count']));
}
/*------------------------------------------------------ */
//-- 退貨單詳細
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'back_info')
{
/* 檢查權限 */
admin_priv('back_view');
$back_id = intval(trim($_REQUEST['back_id']));
/* 根據發貨單id查詢發貨單信息 */
if (!empty($back_id))
{
$back_order = back_order_info($back_id);
}
else
{
die('order does not exist');
}
/* 如果管理員屬於某個辦事處,檢查該訂單是否也屬於這個辦事處 */
$sql = "SELECT agency_id FROM " . $ecs->table('admin_user') . " WHERE user_id = '$_SESSION[admin_id]'";
$agency_id = $db->getOne($sql);
if ($agency_id > 0)
{
if ($back_order['agency_id'] != $agency_id)
{
sys_msg($_LANG['priv_error']);
}
/* 取當前辦事處信息*/
$sql = "SELECT agency_name FROM " . $ecs->table('agency') . " WHERE agency_id = '$agency_id' LIMIT 0, 1";
$agency_name = $db->getOne($sql);
$back_order['agency_name'] = $agency_name;
}
/* 取得用户名 */
if ($back_order['user_id'] > 0)
{
$user = user_info($back_order['user_id']);
if (!empty($user))
{
$back_order['user_name'] = $user['user_name'];
}
}
/* 取得區域名 */
$sql = "SELECT concat(IFNULL(c.region_name, ''), ' ', IFNULL(p.region_name, ''), " .
"' ', IFNULL(t.region_name, ''), ' ', IFNULL(d.region_name, '')) AS region " .
"FROM " . $ecs->table('order_info') . " AS o " .
"LEFT JOIN " . $ecs->table('region') . " AS c ON o.country = c.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS p ON o.province = p.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS t ON o.city = t.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS d ON o.district = d.region_id " .
"WHERE o.order_id = '" . $back_order['order_id'] . "'";
$back_order['region'] = $db->getOne($sql);
/* 是否保價 */
$order['insure_yn'] = empty($order['insure_fee']) ? 0 : 1;
/* 取得發貨單產品 */
$goods_sql = "SELECT *
FROM " . $ecs->table('back_goods') . "
WHERE back_id = " . $back_order['back_id'];
$goods_list = $GLOBALS['db']->getAll($goods_sql);
/* 是否存在實體產品 */
$exist_real_goods = 0;
if ($goods_list)
{
foreach ($goods_list as $value)
{
if ($value['is_real'])
{
$exist_real_goods++;
}
}
}
/* 模板賦值 */
$smarty->assign('back_order', $back_order);
$smarty->assign('exist_real_goods', $exist_real_goods);
$smarty->assign('goods_list', $goods_list);
$smarty->assign('back_id', $back_id); // 發貨單id
/* 顯示模板 */
$smarty->assign('ur_here', $_LANG['back_operate'] . $_LANG['detail']);
$smarty->assign('action_link', array('href' => 'order.php?act=back_list&' . list_link_postfix(), 'text' => $_LANG['10_back_order']));
assign_query_info();
$smarty->display('back_info.htm');
exit; //
}
/*------------------------------------------------------ */
//-- 修改訂單(處理提交)
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'step_post')
{
/* 檢查權限 */
admin_priv('order_edit');
/* 取得參數 step */
$step_list = array('user', 'edit_goods', 'add_goods', 'goods', 'consignee', 'shipping', 'payment', 'other', 'money', 'invoice');
$step = isset($_REQUEST['step']) && in_array($_REQUEST['step'], $step_list) ? $_REQUEST['step'] : 'user';
/* 取得參數 order_id */
$order_id = isset($_REQUEST['order_id']) ? intval($_REQUEST['order_id']) : 0;
if ($order_id > 0)
{
$old_order = order_info($order_id);
}
/* 取得參數 step_act 添加還是編輯 */
$step_act = isset($_REQUEST['step_act']) ? $_REQUEST['step_act'] : 'add';
/* 插入訂單信息 */
if ('user' == $step)
{
/* 取得參數user_id */
$user_id = ($_POST['anonymous'] == 1) ? 0 : intval($_POST['user']);
/* 插入新訂單,狀態為無效 */
$order = array(
'user_id' => $user_id,
'add_time' => gmtime(),
'order_status' => OS_INVALID,
'shipping_status' => SS_UNSHIPPED,
'pay_status' => PS_UNPAYED,
'from_ad' => 0,
'referer' => $_LANG['admin']
);
do
{
$order['order_sn'] = get_order_sn();
if ($db->autoExecute($ecs->table('order_info'), $order, 'INSERT', '', 'SILENT'))
{
break;
}
else
{
if ($db->errno() != 1062)
{
die($db->error());
}
}
}
while (true); // 防止訂單號重複
$order_id = $db->insert_id();
/* todo 記錄日誌 */
admin_log($order['order_sn'], 'add', 'order');
/* 插入 pay_log */
$sql = 'INSERT INTO ' . $ecs->table('pay_log') . " (order_id, order_amount, order_type, is_paid)" .
" VALUES ('$order_id', 0, '" . PAY_ORDER . "', 0)";
$db->query($sql);
/* 下一步 */
ecs_header("Location: order.php?act=" . $step_act . "&order_id=" . $order_id . "&step=goods\n");
exit;
}
/* 編輯產品信息 */
elseif ('edit_goods' == $step)
{
if (isset($_POST['rec_id']))
{
foreach ($_POST['rec_id'] AS $key => $rec_id)
{
$sql = "SELECT goods_number ".
'FROM ' . $GLOBALS['ecs']->table('goods') .
"WHERE goods_id =".$_POST['goods_id'][$key];
/* 取得參數 */
$goods_price = floatval($_POST['goods_price'][$key]);
$goods_number = intval($_POST['goods_number'][$key]);
$goods_attr = $_POST['goods_attr'][$key];
$product_id = intval($_POST['product_id'][$key]);
if($product_id)
{
$sql = "SELECT product_number ".
'FROM ' . $GLOBALS['ecs']->table('products') .
" WHERE product_id =".$_POST['product_id'][$key];
}
$goods_number_all = $db->getOne($sql);
if($goods_number_all>=$goods_number)
{
/* 修改 */
$sql = "UPDATE " . $ecs->table('order_goods') .
" SET goods_price = '$goods_price', " .
"goods_number = '$goods_number', " .
"goods_attr = '$goods_attr' " .
"WHERE rec_id = '$rec_id' LIMIT 1";
$db->query($sql);
}
else
{
sys_msg($_LANG['goods_num_err']);
}
}
/* 更新產品總金額和訂單總金額 */
$goods_amount = order_amount($order_id);
update_order($order_id, array('goods_amount' => $goods_amount));
update_order_amount($order_id);
/* 更新 pay_log */
update_pay_log($order_id);
/* todo 記錄日誌 */
$sn = $old_order['order_sn'];
$new_order = order_info($order_id);
if ($old_order['total_fee'] != $new_order['total_fee'])
{
$sn .= ',' . sprintf($_LANG['order_amount_change'], $old_order['total_fee'], $new_order['total_fee']);
}
admin_log($sn, 'edit', 'order');
}
/* 跳回訂單產品 */
ecs_header("Location: order.php?act=" . $step_act . "&order_id=" . $order_id . "&step=goods\n");
exit;
}
/* 添加產品 */
elseif ('add_goods' == $step)
{
/* 取得參數 */
$goods_id = intval($_POST['goodslist']);
$goods_price = $_POST['add_price'] != 'user_input' ? floatval($_POST['add_price']) : floatval($_POST['input_price']);
$goods_attr = '0';
for ($i = 0; $i < $_POST['spec_count']; $i++)
{
if (is_array($_POST['spec_' . $i]))
{
$temp_array = $_POST['spec_' . $i];
$temp_array_count = count($_POST['spec_' . $i]);
for ($j = 0; $j < $temp_array_count; $j++)
{
if($temp_array[$j]!==NULL)
{
$goods_attr .= ',' . $temp_array[$j];
}
}
}
else
{
if($_POST['spec_' . $i]!==NULL)
{
$goods_attr .= ',' . $_POST['spec_' . $i];
}
}
}
$goods_number = $_POST['add_number'];
$attr_list = $goods_attr;
$goods_attr = explode(',',$goods_attr);
$k = array_search(0,$goods_attr);
unset($goods_attr[$k]);
$sql = "SELECT attr_value ".
'FROM ' . $GLOBALS['ecs']->table('goods_attr') .
"WHERE goods_attr_id in($attr_list)";
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
$attr_value[] = $row['attr_value'];
}
$attr_value = implode(",",$attr_value);
$sql = "SELECT * FROM " .$GLOBALS['ecs']->table('products'). " WHERE goods_id = '$goods_id' LIMIT 0, 1";
$prod = $GLOBALS['db']->getRow($sql);
if (is_spec($goods_attr) && !empty($prod))
{
$product_info = get_products_info($_REQUEST['goodslist'], $goods_attr);
}
//產品存在規格 是貨品 檢查該貨品庫存
if (is_spec($goods_attr) && !empty($prod))
{
if (!empty($goods_attr))
{
/* 取規格的貨品庫存 */
if ($goods_number > $product_info['product_number'])
{
$url = "order.php?act=" . $step_act . "&order_id=" . $order_id . "&step=goods";
echo '<a href="'.$url.'">'.$_LANG['goods_num_err'] .'</a>';
exit;
return false;
}
}
}
if(is_spec($goods_attr) && !empty($prod))
{
/* 插入訂單產品 */
$sql = "INSERT INTO " . $ecs->table('order_goods') .
"(order_id, goods_id, goods_name, goods_sn, product_id, goods_number, market_price, " .
"goods_price, goods_attr, is_real, extension_code, parent_id, is_gift, goods_attr_id) " .
"SELECT '$order_id', goods_id, goods_name, goods_sn, " .$product_info['product_id'].", ".
"'$goods_number', market_price, '$goods_price', '" .$attr_value . "', " .
"is_real, extension_code, 0, 0 , '".implode(',',$goods_attr)."' " .
"FROM " . $ecs->table('goods') .
" WHERE goods_id = '$goods_id' LIMIT 1";
}
else
{
$sql = "INSERT INTO " . $ecs->table('order_goods') .
" (order_id, goods_id, goods_name, goods_sn, " .
"goods_number, market_price, goods_price, goods_attr, " .
"is_real, extension_code, parent_id, is_gift)" .
"SELECT '$order_id', goods_id, goods_name, goods_sn, " .
"'$goods_number', market_price, '$goods_price', '" . $attr_value. "', " .
"is_real, extension_code, 0, 0 " .
"FROM " . $ecs->table('goods') .
" WHERE goods_id = '$goods_id' LIMIT 1";
}
$db->query($sql);
/* 如果使用庫存,且下訂單時減庫存,則修改庫存 */
if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_PLACE)
{
//(貨品)
if (!empty($product_info['product_id']))
{
$sql = "UPDATE " . $ecs->table('products') . "
SET product_number = product_number - " . $goods_number . "
WHERE product_id = " . $product_info['product_id'];
$db->query($sql);
}
$sql = "UPDATE " . $ecs->table('goods') .
" SET `goods_number` = goods_number - '" . $goods_number . "' " .
" WHERE `goods_id` = '" . $goods_id . "' LIMIT 1";
$db->query($sql);
}
/* 更新產品總金額和訂單總金額 */
update_order($order_id, array('goods_amount' => order_amount($order_id)));
update_order_amount($order_id);
/* 更新 pay_log */
update_pay_log($order_id);
/* todo 記錄日誌 */
$sn = $old_order['order_sn'];
$new_order = order_info($order_id);
if ($old_order['total_fee'] != $new_order['total_fee'])
{
$sn .= ',' . sprintf($_LANG['order_amount_change'], $old_order['total_fee'], $new_order['total_fee']);
}
admin_log($sn, 'edit', 'order');
/* 跳回訂單產品 */
ecs_header("Location: order.php?act=" . $step_act . "&order_id=" . $order_id . "&step=goods\n");
exit;
}
/* 產品 */
elseif ('goods' == $step)
{
/* 下一步 */
if (isset($_POST['next']))
{
ecs_header("Location: order.php?act=" . $step_act . "&order_id=" . $order_id . "&step=consignee\n");
exit;
}
/* 完成 */
elseif (isset($_POST['finish']))
{
/* 初始化提示信息和鏈接 */
$msgs = array();
$links = array();
/* 如果已付款,檢查金額是否變動,並執行相應操作 */
$order = order_info($order_id);
handle_order_money_change($order, $msgs, $links);
/* 顯示提示信息 */
if (!empty($msgs))
{
sys_msg(join(chr(13), $msgs), 0, $links);
}
else
{
/* 跳轉到訂單詳情 */
ecs_header("Location: order.php?act=info&order_id=" . $order_id . "\n");
exit;
}
}
}
/* 保存收貨人信息 */
elseif ('consignee' == $step)
{
/* 保存訂單 */
$order = $_POST;
$order['agency_id'] = get_agency_by_regions(array($order['country'], $order['province'], $order['city'], $order['district']));
update_order($order_id, $order);
/* 該訂單所屬辦事處是否變化 */
$agency_changed = $old_order['agency_id'] != $order['agency_id'];
/* todo 記錄日誌 */
$sn = $old_order['order_sn'];
admin_log($sn, 'edit', 'order');
if (isset($_POST['next']))
{
/* 下一步 */
if (exist_real_goods($order_id))
{
/* 存在實體產品,去配送方式 */
ecs_header("Location: order.php?act=" . $step_act . "&order_id=" . $order_id . "&step=shipping\n");
exit;
}
else
{
/* 不存在實體產品,去支付方式 */
ecs_header("Location: order.php?act=" . $step_act . "&order_id=" . $order_id . "&step=payment\n");
exit;
}
}
elseif (isset($_POST['finish']))
{
/* 如果是編輯且存在實體產品,檢查收貨人地區的改變是否影響原來選的配送 */
if ('edit' == $step_act && exist_real_goods($order_id))
{
$order = order_info($order_id);
/* 取得可用配送方式 */
$region_id_list = array(
$order['country'], $order['province'], $order['city'], $order['district']
);
$shipping_list = available_shipping_list($region_id_list);
/* 判斷訂單的配送是否在可用配送之內 */
$exist = false;
foreach ($shipping_list AS $shipping)
{
if ($shipping['shipping_id'] == $order['shipping_id'])
{
$exist = true;
break;
}
}
/* 如果不在可用配送之內,提示用户去修改配送 */
if (!$exist)
{
// 修改配送為空配送費和保價費為0
update_order($order_id, array('shipping_id' => 0, 'shipping_name' => ''));
$links[] = array('text' => $_LANG['step']['shipping'], 'href' => 'order.php?act=edit&order_id=' . $order_id . '&step=shipping');
sys_msg($_LANG['continue_shipping'], 1, $links);
}
}
/* 完成 */
if ($agency_changed)
{
ecs_header("Location: order.php?act=list\n");
}
else
{
ecs_header("Location: order.php?act=info&order_id=" . $order_id . "\n");
}
exit;
}
}
/* 保存配送信息 */
elseif ('shipping' == $step)
{
/* 如果不存在實體產品,退出 */
if (!exist_real_goods($order_id))
{
die ('Hacking Attemp');
}
/* 取得訂單信息 */
$order_info = order_info($order_id);
$region_id_list = array($order_info['country'], $order_info['province'], $order_info['city'], $order_info['district']);
/* 保存訂單 */
$shipping_id = $_POST['shipping'];
$shipping = shipping_area_info($shipping_id, $region_id_list);
$weight_amount = order_weight_price($order_id);
$shipping_fee = shipping_fee($shipping['shipping_code'], $shipping['configure'], $weight_amount['weight'], $weight_amount['amount'], $weight_amount['number']);
$order = array(
'shipping_id' => $shipping_id,
'shipping_name' => addslashes($shipping['shipping_name']),
'shipping_fee' => $shipping_fee
);
if (isset($_POST['insure']))
{
/* 計算保價費 */
$order['insure_fee'] = shipping_insure_fee($shipping['shipping_code'], order_amount($order_id), $shipping['insure']);
}
else
{
$order['insure_fee'] = 0;
}
update_order($order_id, $order);
update_order_amount($order_id);
/* 更新 pay_log */
update_pay_log($order_id);
/* 清除首頁緩存:發貨單查詢 */
clear_cache_files('index.dwt');
/* todo 記錄日誌 */
$sn = $old_order['order_sn'];
$new_order = order_info($order_id);
if ($old_order['total_fee'] != $new_order['total_fee'])
{
$sn .= ',' . sprintf($_LANG['order_amount_change'], $old_order['total_fee'], $new_order['total_fee']);
}
admin_log($sn, 'edit', 'order');
if (isset($_POST['next']))
{
/* 下一步 */
ecs_header("Location: order.php?act=" . $step_act . "&order_id=" . $order_id . "&step=payment\n");
exit;
}
elseif (isset($_POST['finish']))
{
/* 初始化提示信息和鏈接 */
$msgs = array();
$links = array();
/* 如果已付款,檢查金額是否變動,並執行相應操作 */
$order = order_info($order_id);
handle_order_money_change($order, $msgs, $links);
/* 如果是編輯且配送不支持貨到付款且原支付方式是貨到付款 */
if ('edit' == $step_act && $shipping['support_cod'] == 0)
{
$payment = payment_info($order['pay_id']);
if ($payment['is_cod'] == 1)
{
/* 修改支付為空 */
update_order($order_id, array('pay_id' => 0, 'pay_name' => ''));
$msgs[] = $_LANG['continue_payment'];
$links[] = array('text' => $_LANG['step']['payment'], 'href' => 'order.php?act=' . $step_act . '&order_id=' . $order_id . '&step=payment');
}
}
/* 顯示提示信息 */
if (!empty($msgs))
{
sys_msg(join(chr(13), $msgs), 0, $links);
}
else
{
/* 完成 */
ecs_header("Location: order.php?act=info&order_id=" . $order_id . "\n");
exit;
}
}
}
/* 保存支付信息 */
elseif ('payment' == $step)
{
/* 取得支付信息 */
$pay_id = $_POST['payment'];
$payment = payment_info($pay_id);
/* 計算支付費用 */
$order_amount = order_amount($order_id);
if ($payment['is_cod'] == 1)
{
$order = order_info($order_id);
$region_id_list = array(
$order['country'], $order['province'], $order['city'], $order['district']
);
$shipping = shipping_area_info($order['shipping_id'], $region_id_list);
$pay_fee = pay_fee($pay_id, $order_amount, $shipping['pay_fee']);
}
else
{
$pay_fee = pay_fee($pay_id, $order_amount);
}
/* 保存訂單 */
$order = array(
'pay_id' => $pay_id,
'pay_name' => addslashes($payment['pay_name']),
'pay_fee' => $pay_fee
);
update_order($order_id, $order);
update_order_amount($order_id);
/* 更新 pay_log */
update_pay_log($order_id);
/* todo 記錄日誌 */
$sn = $old_order['order_sn'];
$new_order = order_info($order_id);
if ($old_order['total_fee'] != $new_order['total_fee'])
{
$sn .= ',' . sprintf($_LANG['order_amount_change'], $old_order['total_fee'], $new_order['total_fee']);
}
admin_log($sn, 'edit', 'order');
if (isset($_POST['next']))
{
/* 下一步 */
ecs_header("Location: order.php?act=" . $step_act . "&order_id=" . $order_id . "&step=other\n");
exit;
}
elseif (isset($_POST['finish']))
{
/* 初始化提示信息和鏈接 */
$msgs = array();
$links = array();
/* 如果已付款,檢查金額是否變動,並執行相應操作 */
$order = order_info($order_id);
handle_order_money_change($order, $msgs, $links);
/* 顯示提示信息 */
if (!empty($msgs))
{
sys_msg(join(chr(13), $msgs), 0, $links);
}
else
{
/* 完成 */
ecs_header("Location: order.php?act=info&order_id=" . $order_id . "\n");
exit;
}
}
}
elseif ('other' == $step)
{
/* 保存訂單 */
$order = array();
if (isset($_POST['pack']) && $_POST['pack'] > 0)
{
$pack = pack_info($_POST['pack']);
$order['pack_id'] = $pack['pack_id'];
$order['pack_name'] = addslashes($pack['pack_name']);
$order['pack_fee'] = $pack['pack_fee'];
}
else
{
$order['pack_id'] = 0;
$order['pack_name'] = '';
$order['pack_fee'] = 0;
}
if (isset($_POST['card']) && $_POST['card'] > 0)
{
$card = card_info($_POST['card']);
$order['card_id'] = $card['card_id'];
$order['card_name'] = addslashes($card['card_name']);
$order['card_fee'] = $card['card_fee'];
$order['card_message'] = $_POST['card_message'];
}
else
{
$order['card_id'] = 0;
$order['card_name'] = '';
$order['card_fee'] = 0;
$order['card_message'] = '';
}
$order['inv_type'] = $_POST['inv_type'];
$order['inv_payee'] = $_POST['inv_payee'];
$order['inv_content'] = $_POST['inv_content'];
$order['how_oos'] = $_POST['how_oos'];
$order['postscript'] = $_POST['postscript'];
$order['to_buyer'] = $_POST['to_buyer'];
update_order($order_id, $order);
update_order_amount($order_id);
/* 更新 pay_log */
update_pay_log($order_id);
/* todo 記錄日誌 */
$sn = $old_order['order_sn'];
admin_log($sn, 'edit', 'order');
if (isset($_POST['next']))
{
/* 下一步 */
ecs_header("Location: order.php?act=" . $step_act . "&order_id=" . $order_id . "&step=money\n");
exit;
}
elseif (isset($_POST['finish']))
{
/* 完成 */
ecs_header("Location: order.php?act=info&order_id=" . $order_id . "\n");
exit;
}
}
elseif ('money' == $step)
{
/* 取得訂單信息 */
$old_order = order_info($order_id);
if ($old_order['user_id'] > 0)
{
/* 取得用户信息 */
$user = user_info($old_order['user_id']);
}
/* 保存信息 */
$order['goods_amount'] = $old_order['goods_amount'];
$order['discount'] = isset($_POST['discount']) && floatval($_POST['discount']) >= 0 ? round(floatval($_POST['discount']), 2) : 0;
$order['tax'] = round(floatval($_POST['tax']), 2);
$order['shipping_fee'] = isset($_POST['shipping_fee']) && floatval($_POST['shipping_fee']) >= 0 ? round(floatval($_POST['shipping_fee']), 2) : 0;
$order['insure_fee'] = isset($_POST['insure_fee']) && floatval($_POST['insure_fee']) >= 0 ? round(floatval($_POST['insure_fee']), 2) : 0;
$order['pay_fee'] = floatval($_POST['pay_fee']) >= 0 ? round(floatval($_POST['pay_fee']), 2) : 0;
$order['pack_fee'] = isset($_POST['pack_fee']) && floatval($_POST['pack_fee']) >= 0 ? round(floatval($_POST['pack_fee']), 2) : 0;
$order['card_fee'] = isset($_POST['card_fee']) && floatval($_POST['card_fee']) >= 0 ? round(floatval($_POST['card_fee']), 2) : 0;
$order['money_paid'] = $old_order['money_paid'];
$order['surplus'] = 0;
//$order['integral'] = 0;
$order['integral']=intval($_POST['integral']) >= 0 ? intval($_POST['integral']) : 0;
$order['integral_money']= 0;
$order['bonus_id'] = 0;
$order['bonus'] = 0;
/* 計算待付款金額 */
$order['order_amount'] = $order['goods_amount'] - $order['discount']
+ $order['tax']
+ $order['shipping_fee']
+ $order['insure_fee']
+ $order['pay_fee']
+ $order['pack_fee']
+ $order['card_fee']
- $order['money_paid'];
if ($order['order_amount'] > 0)
{
if ($old_order['user_id'] > 0)
{
/* 如果選擇了紅包,先使用紅包支付 */
if ($_POST['bonus_id'] > 0)
{
/* todo 檢查紅包是否可用 */
$order['bonus_id'] = $_POST['bonus_id'];
$bonus = bonus_info($_POST['bonus_id']);
$order['bonus'] = $bonus['type_money'];
$order['order_amount'] -= $order['bonus'];
}
/* 使用紅包之後待付款金額仍大於0 */
if ($order['order_amount'] > 0)
{
if($old_order['extension_code']!='exchange_goods')
{
/* 如果設置了積分,再使用積分支付 */
if (isset($_POST['integral']) && intval($_POST['integral']) > 0)
{
/* 檢查積分是否足夠 */
$order['integral'] = intval($_POST['integral']);
$order['integral_money'] = value_of_integral(intval($_POST['integral']));
if ($old_order['integral'] + $user['pay_points'] < $order['integral'])
{
sys_msg($_LANG['pay_points_not_enough']);
}
$order['order_amount'] -= $order['integral_money'];
}
}
else
{
if (intval($_POST['integral']) > $user['pay_points']+$old_order['integral'])
{
sys_msg($_LANG['pay_points_not_enough']);
}
}
if ($order['order_amount'] > 0)
{
/* 如果設置了餘額,再使用餘額支付 */
if (isset($_POST['surplus']) && floatval($_POST['surplus']) >= 0)
{
/* 檢查餘額是否足夠 */
$order['surplus'] = round(floatval($_POST['surplus']), 2);
if ($old_order['surplus'] + $user['user_money'] + $user['credit_line'] < $order['surplus'])
{
sys_msg($_LANG['user_money_not_enough']);
}
/* 如果紅包和積分和餘額足以支付把待付款金額改為0退回部分積分餘額 */
$order['order_amount'] -= $order['surplus'];
if ($order['order_amount'] < 0)
{
$order['surplus'] += $order['order_amount'];
$order['order_amount'] = 0;
}
}
}
else
{
/* 如果紅包和積分足以支付把待付款金額改為0退回部分積分 */
$order['integral_money'] += $order['order_amount'];
$order['integral'] = integral_of_value($order['integral_money']);
$order['order_amount'] = 0;
}
}
else
{
/* 如果紅包足以支付把待付款金額設為0 */
$order['order_amount'] = 0;
}
}
}
update_order($order_id, $order);
/* 更新 pay_log */
update_pay_log($order_id);
/* todo 記錄日誌 */
$sn = $old_order['order_sn'];
$new_order = order_info($order_id);
if ($old_order['total_fee'] != $new_order['total_fee'])
{
$sn .= ',' . sprintf($_LANG['order_amount_change'], $old_order['total_fee'], $new_order['total_fee']);
}
admin_log($sn, 'edit', 'order');
/* 如果餘額、積分、紅包有變化,做相應更新 */
if ($old_order['user_id'] > 0)
{
$user_money_change = $old_order['surplus'] - $order['surplus'];
if ($user_money_change != 0)
{
log_account_change($user['user_id'], $user_money_change, 0, 0, 0, sprintf($_LANG['change_use_surplus'], $old_order['order_sn']));
}
$pay_points_change = $old_order['integral'] - $order['integral'];
if ($pay_points_change != 0)
{
log_account_change($user['user_id'], 0, 0, 0, $pay_points_change, sprintf($_LANG['change_use_integral'], $old_order['order_sn']));
}
if ($old_order['bonus_id'] != $order['bonus_id'])
{
if ($old_order['bonus_id'] > 0)
{
$sql = "UPDATE " . $ecs->table('user_bonus') .
" SET used_time = 0, order_id = 0 " .
"WHERE bonus_id = '$old_order[bonus_id]' LIMIT 1";
$db->query($sql);
}
if ($order['bonus_id'] > 0)
{
$sql = "UPDATE " . $ecs->table('user_bonus') .
" SET used_time = '" . gmtime() . "', order_id = '$order_id' " .
"WHERE bonus_id = '$order[bonus_id]' LIMIT 1";
$db->query($sql);
}
}
}
if (isset($_POST['finish']))
{
/* 完成 */
if ($step_act == 'add')
{
/* 訂單改為已確認,(已付款) */
$arr['order_status'] = OS_CONFIRMED;
$arr['confirm_time'] = gmtime();
if ($order['order_amount'] <= 0)
{
$arr['pay_status'] = PS_PAYED;
$arr['pay_time'] = gmtime();
}
update_order($order_id, $arr);
}
/* 初始化提示信息和鏈接 */
$msgs = array();
$links = array();
/* 如果已付款,檢查金額是否變動,並執行相應操作 */
$order = order_info($order_id);
handle_order_money_change($order, $msgs, $links);
/* 顯示提示信息 */
if (!empty($msgs))
{
sys_msg(join(chr(13), $msgs), 0, $links);
}
else
{
ecs_header("Location: order.php?act=info&order_id=" . $order_id . "\n");
exit;
}
}
}
/* 保存發貨後的配送方式和發貨單號 */
elseif ('invoice' == $step)
{
/* 如果不存在實體產品,退出 */
if (!exist_real_goods($order_id))
{
die ('Hacking Attemp');
}
/* 保存訂單 */
$shipping_id = $_POST['shipping'];
$shipping = shipping_info($shipping_id);
$invoice_no = trim($_POST['invoice_no']);
$invoice_no = str_replace(',', '<br>', $invoice_no);
$order = array(
'shipping_id' => $shipping_id,
'shipping_name' => addslashes($shipping['shipping_name']),
'invoice_no' => $invoice_no
);
update_order($order_id, $order);
/* todo 記錄日誌 */
$sn = $old_order['order_sn'];
admin_log($sn, 'edit', 'order');
if (isset($_POST['finish']))
{
ecs_header("Location: order.php?act=info&order_id=" . $order_id . "\n");
exit;
}
}
}
/*------------------------------------------------------ */
//-- 修改訂單(載入頁面)
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'add' || $_REQUEST['act'] == 'edit')
{
/* 檢查權限 */
admin_priv('order_edit');
/* 取得參數 order_id */
$order_id = isset($_GET['order_id']) ? intval($_GET['order_id']) : 0;
$smarty->assign('order_id', $order_id);
/* 取得參數 step */
$step_list = array('user', 'goods', 'consignee', 'shipping', 'payment', 'other', 'money');
$step = isset($_GET['step']) && in_array($_GET['step'], $step_list) ? $_GET['step'] : 'user';
$smarty->assign('step', $step);
/* 取得參數 act */
$act = $_GET['act'];
$smarty->assign('ur_here',$_LANG['add_order']);
$smarty->assign('step_act', $act);
/* 取得訂單信息 */
if ($order_id > 0)
{
$order = order_info($order_id);
/* 發貨單格式化 */
$order['invoice_no'] = str_replace('<br>', ',', $order['invoice_no']);
/* 如果已發貨,就不能修改訂單了(配送方式和發貨單號除外) */
if ($order['shipping_status'] == SS_SHIPPED || $order['shipping_status'] == SS_RECEIVED)
{
if ($step != 'shipping')
{
sys_msg($_LANG['cannot_edit_order_shipped']);
}
else
{
$step = 'invoice';
$smarty->assign('step', $step);
}
}
$smarty->assign('order', $order);
}
else
{
if ($act != 'add' || $step != 'user')
{
die('invalid params');
}
}
/* 選擇客戶 */
if ('user' == $step)
{
// 無操作
}
/* 增刪改產品 */
elseif ('goods' == $step)
{
/* 取得訂單產品 */
$goods_list = order_goods($order_id);
if (!empty($goods_list))
{
foreach ($goods_list AS $key => $goods)
{
/* 計算屬性數 */
$attr = $goods['goods_attr'];
if ($attr == '')
{
$goods_list[$key]['rows'] = 1;
}
else
{
$goods_list[$key]['rows'] = count(explode(chr(13), $attr));
}
}
}
$smarty->assign('goods_list', $goods_list);
/* 取得產品總金額 */
$smarty->assign('goods_amount', order_amount($order_id));
}
// 設置收貨人
elseif ('consignee' == $step)
{
/* 查詢是否存在實體產品 */
$exist_real_goods = exist_real_goods($order_id);
$smarty->assign('exist_real_goods', $exist_real_goods);
/* 取得收貨地址列表 */
if ($order['user_id'] > 0)
{
$smarty->assign('address_list', address_list($order['user_id']));
$address_id = isset($_REQUEST['address_id']) ? intval($_REQUEST['address_id']) : 0;
if ($address_id > 0)
{
$address = address_info($address_id);
if ($address)
{
$order['consignee'] = $address['consignee'];
$order['country'] = $address['country'];
$order['province'] = $address['province'];
$order['city'] = $address['city'];
$order['district'] = $address['district'];
$order['email'] = $address['email'];
$order['address'] = $address['address'];
$order['zipcode'] = $address['zipcode'];
$order['tel'] = $address['tel'];
$order['mobile'] = $address['mobile'];
$order['sign_building'] = $address['sign_building'];
$order['best_time'] = $address['best_time'];
$smarty->assign('order', $order);
}
}
}
if ($exist_real_goods)
{
/* 取得國家 */
$smarty->assign('country_list', get_regions());
if ($order['country'] > 0)
{
/* 取得省份 */
$smarty->assign('province_list', get_regions(1, $order['country']));
if ($order['province'] > 0)
{
/* 取得城市 */
$smarty->assign('city_list', get_regions(2, $order['province']));
if ($order['city'] > 0)
{
/* 取得區域 */
$smarty->assign('district_list', get_regions(3, $order['city']));
}
}
}
}
}
// 選擇配送方式
elseif ('shipping' == $step)
{
/* 如果不存在實體產品 */
if (!exist_real_goods($order_id))
{
die ('Hacking Attemp');
}
/* 取得可用的配送方式列表 */
$region_id_list = array(
$order['country'], $order['province'], $order['city'], $order['district']
);
$shipping_list = available_shipping_list($region_id_list);
/* 取得配送費用 */
$total = order_weight_price($order_id);
foreach ($shipping_list AS $key => $shipping)
{
$shipping['configure'] = unserialize($shipping['configure']);
$shipping_fee = shipping_fee($shipping['shipping_code'],
$shipping['configure'], $total['weight'], $total['amount'], $total['number']);
$shipping_list[$key]['shipping_fee'] = $shipping_fee;
$shipping_list[$key]['format_shipping_fee'] = price_format($shipping_fee);
$shipping_list[$key]['free_money'] = price_format($shipping['configure']['free_money']);
}
$smarty->assign('shipping_list', $shipping_list);
}
// 選擇支付方式
elseif ('payment' == $step)
{
/* 取得可用的支付方式列表 */
if (exist_real_goods($order_id))
{
/* 存在實體產品 */
$region_id_list = array(
$order['country'], $order['province'], $order['city'], $order['district']
);
$shipping_area = shipping_area_info($order['shipping_id'], $region_id_list);
$pay_fee = ($shipping_area['support_cod'] == 1) ? $shipping_area['pay_fee'] : 0;
$payment_list = available_payment_list($shipping_area['support_cod'], $pay_fee);
}
else
{
/* 不存在實體產品 */
$payment_list = available_payment_list(false);
}
/* 過濾掉使用餘額支付 */
foreach ($payment_list as $key => $payment)
{
if ($payment['pay_code'] == 'balance')
{
unset($payment_list[$key]);
}
}
$smarty->assign('payment_list', $payment_list);
}
// 選擇包裝、賀卡
elseif ('other' == $step)
{
/* 查詢是否存在實體產品 */
$exist_real_goods = exist_real_goods($order_id);
$smarty->assign('exist_real_goods', $exist_real_goods);
if ($exist_real_goods)
{
/* 取得包裝列表 */
$smarty->assign('pack_list', pack_list());
/* 取得賀卡列表 */
$smarty->assign('card_list', card_list());
}
}
// 費用
elseif ('money' == $step)
{
/* 查詢是否存在實體產品 */
$exist_real_goods = exist_real_goods($order_id);
$smarty->assign('exist_real_goods', $exist_real_goods);
/* 取得用户信息 */
if ($order['user_id'] > 0)
{
$user = user_info($order['user_id']);
/* 計算可用餘額 */
$smarty->assign('available_user_money', $order['surplus'] + $user['user_money']);
/* 計算可用積分 */
$smarty->assign('available_pay_points', $order['integral'] + $user['pay_points']);
/* 取得用户可用紅包 */
$user_bonus = user_bonus($order['user_id'], $order['goods_amount']);
if ($order['bonus_id'] > 0)
{
$bonus = bonus_info($order['bonus_id']);
$user_bonus[] = $bonus;
}
$smarty->assign('available_bonus', $user_bonus);
}
}
// 發貨後修改配送方式和發貨單號
elseif ('invoice' == $step)
{
/* 如果不存在實體產品 */
if (!exist_real_goods($order_id))
{
die ('Hacking Attemp');
}
/* 取得可用的配送方式列表 */
$region_id_list = array(
$order['country'], $order['province'], $order['city'], $order['district']
);
$shipping_list = available_shipping_list($region_id_list);
// /* 取得配送費用 */
// $total = order_weight_price($order_id);
// foreach ($shipping_list AS $key => $shipping)
// {
// $shipping_fee = shipping_fee($shipping['shipping_code'],
// unserialize($shipping['configure']), $total['weight'], $total['amount'], $total['number']);
// $shipping_list[$key]['shipping_fee'] = $shipping_fee;
// $shipping_list[$key]['format_shipping_fee'] = price_format($shipping_fee);
// $shipping_list[$key]['free_money'] = price_format($shipping['configure']['free_money']);
// }
$smarty->assign('shipping_list', $shipping_list);
}
/* 顯示模板 */
assign_query_info();
$smarty->display('order_step.htm');
}
/*------------------------------------------------------ */
//-- 處理
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'process')
{
/* 取得參數 func */
$func = isset($_GET['func']) ? $_GET['func'] : '';
/* 刪除訂單產品 */
if ('drop_order_goods' == $func)
{
/* 檢查權限 */
admin_priv('order_edit');
/* 取得參數 */
$rec_id = intval($_GET['rec_id']);
$step_act = $_GET['step_act'];
$order_id = intval($_GET['order_id']);
/* 如果使用庫存,且下訂單時減庫存,則修改庫存 */
if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_PLACE)
{
$goods = $db->getRow("SELECT goods_id, goods_number FROM " . $ecs->table('order_goods') . " WHERE rec_id = " . $rec_id );
$sql = "UPDATE " . $ecs->table('goods') .
" SET `goods_number` = goods_number + '" . $goods['goods_number'] . "' " .
" WHERE `goods_id` = '" . $goods['goods_id'] . "' LIMIT 1";
$db->query($sql);
}
/* 刪除 */
$sql = "DELETE FROM " . $ecs->table('order_goods') .
" WHERE rec_id = '$rec_id' LIMIT 1";
$db->query($sql);
/* 更新產品總金額和訂單總金額 */
update_order($order_id, array('goods_amount' => order_amount($order_id)));
update_order_amount($order_id);
/* 跳回訂單產品 */
ecs_header("Location: order.php?act=" . $step_act . "&order_id=" . $order_id . "&step=goods\n");
exit;
}
/* 取消剛添加或編輯的訂單 */
elseif ('cancel_order' == $func)
{
$step_act = $_GET['step_act'];
$order_id = isset($_GET['order_id']) ? intval($_GET['order_id']) : 0;
if ($step_act == 'add')
{
/* 如果是添加,刪除訂單,返回訂單列表 */
if ($order_id > 0)
{
$sql = "DELETE FROM " . $ecs->table('order_info') .
" WHERE order_id = '$order_id' LIMIT 1";
$db->query($sql);
}
ecs_header("Location: order.php?act=list\n");
exit;
}
else
{
/* 如果是編輯,返回訂單信息 */
ecs_header("Location: order.php?act=info&order_id=" . $order_id . "\n");
exit;
}
}
/* 編輯訂單時由於訂單已付款且金額減少而退款 */
elseif ('refund' == $func)
{
/* 處理退款 */
$order_id = $_REQUEST['order_id'];
$refund_type = $_REQUEST['refund'];
$refund_note = $_REQUEST['refund_note'];
$refund_amount = $_REQUEST['refund_amount'];
$order = order_info($order_id);
order_refund($order, $refund_type, $refund_note, $refund_amount);
/* 修改應付款金額為0已付款金額減少 $refund_amount */
update_order($order_id, array('order_amount' => 0, 'money_paid' => $order['money_paid'] - $refund_amount));
/* 返回訂單詳情 */
ecs_header("Location: order.php?act=info&order_id=" . $order_id . "\n");
exit;
}
/* 載入退款頁面 */
elseif ('load_refund' == $func)
{
$refund_amount = floatval($_REQUEST['refund_amount']);
$smarty->assign('refund_amount', $refund_amount);
$smarty->assign('formated_refund_amount', price_format($refund_amount));
$anonymous = $_REQUEST['anonymous'];
$smarty->assign('anonymous', $anonymous); // 是否匿名
$order_id = intval($_REQUEST['order_id']);
$smarty->assign('order_id', $order_id); // 訂單id
/* 顯示模板 */
$smarty->assign('ur_here', $_LANG['refund']);
assign_query_info();
$smarty->display('order_refund.htm');
}
else
{
die('invalid params');
}
}
/*------------------------------------------------------ */
//-- 合併訂單
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'merge')
{
/* 檢查權限 */
admin_priv('order_os_edit');
/* 取得滿足條件的訂單 */
$sql = "SELECT o.order_sn, u.user_name " .
"FROM " . $ecs->table('order_info') . " AS o " .
"LEFT JOIN " . $ecs->table('users') . " AS u ON o.user_id = u.user_id " .
"WHERE o.user_id > 0 " .
"AND o.extension_code = '' " . order_query_sql('unprocessed');
$smarty->assign('order_list', $db->getAll($sql));
/* 模板賦值 */
$smarty->assign('ur_here', $_LANG['04_merge_order']);
$smarty->assign('action_link', array('href' => 'order.php?act=list', 'text' => $_LANG['02_order_list']));
/* 顯示模板 */
assign_query_info();
$smarty->display('merge_order.htm');
}
/*------------------------------------------------------ */
//-- 訂單打印模板(載入頁面)
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'templates')
{
/* 檢查權限 */
admin_priv('order_os_edit');
/* 讀入訂單打印模板文件 */
$file_path = ROOT_PATH. DATA_DIR . '/order_print.html';
$file_content = file_get_contents($file_path);
@fclose($file_content);
include_once(ROOT_PATH."includes/fckeditor/fckeditor.php");
/* 編輯器 */
$editor = new FCKeditor('FCKeditor1');
$editor->BasePath = "../includes/fckeditor/";
$editor->ToolbarSet = "Normal";
$editor->Width = "95%";
$editor->Height = "500";
$editor->Value = $file_content;
$fckeditor = $editor->CreateHtml();
$smarty->assign('fckeditor', $fckeditor);
/* 模板賦值 */
$smarty->assign('ur_here', $_LANG['edit_order_templates']);
$smarty->assign('action_link', array('href' => 'order.php?act=list', 'text' => $_LANG['02_order_list']));
$smarty->assign('act', 'edit_templates');
/* 顯示模板 */
assign_query_info();
$smarty->display('order_templates.htm');
}
/*------------------------------------------------------ */
//-- 訂單打印模板(提交修改)
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'edit_templates')
{
/* 更新模板文件的內容 */
$file_name = @fopen('../' . DATA_DIR . '/order_print.html', 'w+');
@fwrite($file_name, stripslashes($_POST['FCKeditor1']));
@fclose($file_name);
/* 提示信息 */
$link[] = array('text' => $_LANG['back_list'], 'href'=>'order.php?act=list');
sys_msg($_LANG['edit_template_success'], 0, $link);
}
/*------------------------------------------------------ */
//-- 操作訂單狀態(載入頁面)
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'operate')
{
$order_id = '';
/* 檢查權限 */
admin_priv('order_os_edit');
/* 取得訂單id可能是多個多個sn和操作備註可能沒有 */
if(isset($_REQUEST['order_id']))
{
$order_id= $_REQUEST['order_id'];
}
$batch = isset($_REQUEST['batch']); // 是否批處理
$action_note = isset($_REQUEST['action_note']) ? trim($_REQUEST['action_note']) : '';
/* 確認 */
if (isset($_POST['confirm']))
{
$require_note = false;
$action = $_LANG['op_confirm'];
$operation = 'confirm';
}
/*------------------------------------------------------ */
//-- start一鍵發貨 增加 by www.mb5.com.cn
/*------------------------------------------------------ */
elseif (isset($_POST['to_shipping']))
{
$invoice_no = empty($_REQUEST['invoice_no']) ? '' : trim($_REQUEST['invoice_no']); //快遞單號
$order_id = intval(trim($order_id));
$action_note = trim($action_note);
/* 查詢根據訂單id查詢訂單信息 */
if (!empty($order_id))
{
$order = order_info($order_id);
}
else
{
die('order does not exist');
}
/* 查詢:根據訂單是否完成 檢查權限 */
if (order_finished($order))
{
admin_priv('order_view_finished');
}
else
{
admin_priv('order_view');
}
/* 查詢:如果管理員屬於某個辦事處,檢查該訂單是否也屬於這個辦事處 */
$sql = "SELECT agency_id FROM " . $ecs->table('admin_user') . " WHERE user_id = '$_SESSION[admin_id]'";
$agency_id = $db->getOne($sql);
if ($agency_id > 0)
{
if ($order['agency_id'] != $agency_id)
{
sys_msg($_LANG['priv_error'], 0);
}
}
/* 查詢:取得用户名 */
if ($order['user_id'] > 0)
{
$user = user_info($order['user_id']);
if (!empty($user))
{
$order['user_name'] = $user['user_name'];
}
}
/* 查詢:取得區域名 */
$order['region'] = $db->getOne($sql);
/* 查詢:其他處理 */
$order['order_time'] = local_date($_CFG['time_format'], $order['add_time']);
$order['invoice_no'] = $order['shipping_status'] == SS_UNSHIPPED || $order['shipping_status'] == SS_PREPARING ? $_LANG['ss'][SS_UNSHIPPED] : $order['invoice_no'];
/* 查詢:是否保價 */
$order['insure_yn'] = empty($order['insure_fee']) ? 0 : 1;
/* 查詢:是否存在實體產品 */
$exist_real_goods = exist_real_goods($order_id);
/* 查詢:取得訂單產品 */
$_goods = get_order_goods(array('order_id' => $order['order_id'], 'order_sn' =>$order['order_sn']));
$attr = $_goods['attr'];
$goods_list = $_goods['goods_list'];
unset($_goods);
/* 查詢:產品已發貨數量 此單可發貨數量 */
if ($goods_list)
{
foreach ($goods_list as $key => $value)
{
}
foreach ($goods_list as $key=>$goods_value)
{
if (!$goods_value['goods_id'])
{
continue;
}
/* 超級禮包 */
if (($goods_value['extension_code'] == 'package_buy') && (count($goods_value['package_goods_list']) > 0))
{
$goods_list[$key]['package_goods_list'] = package_goods($goods_value['package_goods_list'], $goods_value['goods_number'], $goods_value['order_id'], $goods_value['extension_code'], $goods_value['goods_id']);
foreach ($goods_list[$key]['package_goods_list'] as $pg_key => $pg_value)
{
$goods_list[$key]['package_goods_list'][$pg_key]['readonly'] = '';
/* 使用庫存 是否缺貨 */
if ($pg_value['storage'] <= 0 && $_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP)
{
$goods_list[$key]['package_goods_list'][$pg_key]['send'] = $_LANG['act_good_vacancy'];
$goods_list[$key]['package_goods_list'][$pg_key]['readonly'] = 'readonly="readonly"';
}
/* 將已經全部發貨的產品設置為只讀 */
elseif ($pg_value['send'] <= 0)
{
$goods_list[$key]['package_goods_list'][$pg_key]['send'] = $_LANG['act_good_delivery'];
$goods_list[$key]['package_goods_list'][$pg_key]['readonly'] = 'readonly="readonly"';
}
}
}
else
{
$goods_list[$key]['sended'] = $goods_value['send_number'];
$goods_list[$key]['sended'] = $goods_value['goods_number'];
$goods_list[$key]['send'] = $goods_value['goods_number'] - $goods_value['send_number'];
$goods_list[$key]['readonly'] = '';
/* 是否缺貨 */
if ($goods_value['storage'] <= 0 && $_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP)
{
$goods_list[$key]['send'] = $_LANG['act_good_vacancy'];
$goods_list[$key]['readonly'] = 'readonly="readonly"';
}
elseif ($goods_list[$key]['send'] <= 0)
{
$goods_list[$key]['send'] = $_LANG['act_good_delivery'];
$goods_list[$key]['readonly'] = 'readonly="readonly"';
}
}
}
$suppliers_id = 0;
$delivery['order_sn'] = trim($order['order_sn']);
$delivery['add_time'] = trim($order['order_time']);
$delivery['user_id'] = intval(trim($order['user_id']));
$delivery['how_oos'] = trim($order['how_oos']);
$delivery['shipping_id'] = trim($order['shipping_id']);
$delivery['shipping_fee'] = trim($order['shipping_fee']);
$delivery['consignee'] = trim($order['consignee']);
$delivery['address'] = trim($order['address']);
$delivery['country'] = intval(trim($order['country']));
$delivery['province'] = intval(trim($order['province']));
$delivery['city'] = intval(trim($order['city']));
$delivery['district'] = intval(trim($order['district']));
$delivery['sign_building'] = trim($order['sign_building']);
$delivery['email'] = trim($order['email']);
$delivery['zipcode'] = trim($order['zipcode']);
$delivery['tel'] = trim($order['tel']);
$delivery['mobile'] = trim($order['mobile']);
$delivery['best_time'] = trim($order['best_time']);
$delivery['postscript'] = trim($order['postscript']);
$delivery['how_oos'] = trim($order['how_oos']);
$delivery['insure_fee'] = floatval(trim($order['insure_fee']));
$delivery['shipping_fee'] = floatval(trim($order['shipping_fee']));
$delivery['agency_id'] = intval(trim($order['agency_id']));
$delivery['shipping_name'] = trim($order['shipping_name']);
/* 查詢訂單信息 */
$order = order_info($order_id);
/* 檢查能否操作 */
$operable_list = operable_list($order);
/* 初始化提示信息 */
$msg = '';
/* 定義當前時間 */
/* 取得訂單產品 */
$_goods = get_order_goods(array('order_id' => $order_id, 'order_sn' => $delivery['order_sn']));
$goods_list = $_goods['goods_list'];
/* 檢查此單發貨產品庫存缺貨情況 */
/* $goods_list已經過處理 超值禮包中產品庫存已取得 */
$virtual_goods = array();
$package_virtual_goods = array();
/* 生成發貨單 */
/* 獲取發貨單號和流水號 */
$delivery['delivery_sn'] = get_delivery_sn();
$delivery_sn = $delivery['delivery_sn'];
/* 獲取當前操作員 */
$delivery['action_user'] = $_SESSION['admin_name'];
/* 獲取發貨單生成時間 */
define('GMTIME_UTC', gmtime());
$delivery['update_time'] = GMTIME_UTC;
$delivery_time = $delivery['update_time'];
$sql ="select add_time from ". $GLOBALS['ecs']->table('order_info') ." WHERE order_sn = '" . $delivery['order_sn'] . "'";
$delivery['add_time'] = $GLOBALS['db']->GetOne($sql);
/* 獲取發貨單所屬供應商 */
$delivery['suppliers_id'] = $suppliers_id;
/* 設置默認值 */
$delivery['status'] = 2; // 正常
$delivery['order_id'] = $order_id;
/* 過濾字段項 */
$filter_fileds = array(
'order_sn', 'add_time', 'user_id', 'how_oos', 'shipping_id', 'shipping_fee',
'consignee', 'address', 'country', 'province', 'city', 'district', 'sign_building',
'email', 'zipcode', 'tel', 'mobile', 'best_time', 'postscript', 'insure_fee',
'agency_id', 'delivery_sn', 'action_user', 'update_time',
'suppliers_id', 'status', 'order_id', 'shipping_name'
);
$_delivery = array();
foreach ($filter_fileds as $value)
{
$_delivery[$value] = $delivery[$value];
}
/* 發貨單入庫 */
$query = $db->autoExecute($ecs->table('delivery_order'), $_delivery, 'INSERT', '', 'SILENT');
$delivery_id = $db->insert_id();
$shipping_order_id = $db->getRow("select shipping_id from ".$ecs->table('delivery_order')."where delivery_id=".$delivery_id);
$shipping_order_code = $db->getRow("select shipping_code from ".$ecs->table('shipping')."where shipping_id=".$shipping_order_id['shipping_id']);
if ($shipping_order_code['shipping_code'] == "tc_express")
{
new_kuaidi_order($delivery_id);
update_kuaidi_order($delivery_id, $invoice_no);
}
$sql_back_old = $db->getOne("SELECT back_id FROM " . $ecs->table('back_order') . " WHERE order_id = " . $order['order_id'] . " AND back_type = 4 AND status_back < 6 AND status_back != 3");
if (!empty($sql_back_old))
{
$db->query("UPDATE " . $ecs->table('back_order') . " SET status_back = 6 WHERE back_id = " . $sql_back_old);
$db->query("UPDATE " . $ecs->table('back_goods') . " SET status_back = 6 WHERE back_id = " . $sql_back_old);
}
if ($delivery_id)
{
$delivery_goods = array();
//發貨單產品入庫
if (!empty($goods_list))
{
foreach ($goods_list as $value)
{
// 產品(實貨)(虛貨)
if (empty($value['extension_code']) || $value['extension_code'] == 'virtual_card')
{
$delivery_goods = array('delivery_id' => $delivery_id,
'goods_id' => $value['goods_id'],
'product_id' => $value['product_id'],
'product_sn' => $value['product_sn'],
'goods_id' => $value['goods_id'],
'goods_name' => $value['goods_name'],
'brand_name' => $value['brand_name'],
'goods_sn' => $value['goods_sn'],
'send_number' => $value['goods_number'],
'parent_id' => 0,
'is_real' => $value['is_real'],
'goods_attr' => $value['goods_attr']
);
/* 如果是貨品 */
if (!empty($value['product_id']))
{
$delivery_goods['product_id'] = $value['product_id'];
}
$query = $db->autoExecute($ecs->table('delivery_goods'), $delivery_goods, 'INSERT', '', 'SILENT');
$sql = "UPDATE ".$GLOBALS['ecs']->table('order_goods'). "
SET send_number = " . $value['goods_number'] . "
WHERE order_id = '" . $value['order_id'] . "'
AND goods_id = '" . $value['goods_id'] . "' ";
$GLOBALS['db']->query($sql, 'SILENT');
}
// 產品(超值禮包)
elseif ($value['extension_code'] == 'package_buy')
{
foreach ($value['package_goods_list'] as $pg_key => $pg_value)
{
$delivery_pg_goods = array('delivery_id' => $delivery_id,
'goods_id' => $pg_value['goods_id'],
'product_id' => $pg_value['product_id'],
'product_sn' => $pg_value['product_sn'],
'goods_name' => $pg_value['goods_name'],
'brand_name' => '',
'goods_sn' => $pg_value['goods_sn'],
'send_number' => $value['goods_number'],
'parent_id' => $value['goods_id'], // 禮包ID
'extension_code' => $value['extension_code'], // 禮包
'is_real' => $pg_value['is_real']
);
$query = $db->autoExecute($ecs->table('delivery_goods'), $delivery_pg_goods, 'INSERT', '', 'SILENT');
$sql = "UPDATE ".$GLOBALS['ecs']->table('order_goods'). "
SET send_number = " . $value['goods_number'] . "
WHERE order_id = '" . $value['order_id'] . "'
AND goods_id = '" . $pg_value['goods_id'] . "' ";
$GLOBALS['db']->query($sql, 'SILENT');
}
}
}
}
}
else
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
sys_msg($_LANG['act_false'], 1, $links);
}
unset($filter_fileds, $delivery, $_delivery, $order_finish);
/* 定單信息更新處理 */
if (true)
{
/* 標記訂單為已確認 "發貨中" */
/* 更新發貨時間 */
$order_finish = get_order_finish($order_id);
$shipping_status = SS_SHIPPED_ING;
if ($order['order_status'] != OS_CONFIRMED && $order['order_status'] != OS_SPLITED && $order['order_status'] != OS_SPLITING_PART)
{
$arr['order_status'] = OS_CONFIRMED;
$arr['confirm_time'] = GMTIME_UTC;
}
$arr['order_status'] = $order_finish ? OS_SPLITED : OS_SPLITING_PART; // 全部分單、部分分單
$arr['shipping_status'] = $shipping_status;
update_order($order_id, $arr);
}
/* 記錄log */
order_action($order['order_sn'], $arr['order_status'], $shipping_status, $order['pay_status'], $action_note);
/* 清除緩存 */
clear_cache_files();
/* 根據發貨單id查詢發貨單信息 */
if (!empty($delivery_id))
{
$delivery_order = delivery_order_info($delivery_id);
}
elseif (!empty($order_sn))
{
$delivery_id = $GLOBALS['db']->getOne("SELECT delivery_id FROM " . $ecs->table('delivery_order') . " WHERE order_sn = " . $order_sn );
$delivery_order = delivery_order_info($delivery_id);
}
else
{
die('order does not exist');
}
/* 如果管理員屬於某個辦事處,檢查該訂單是否也屬於這個辦事處 */
$sql = "SELECT agency_id FROM " . $ecs->table('admin_user') . " WHERE user_id = '" . $_SESSION['admin_id'] . "'";
$agency_id = $db->getOne($sql);
if ($agency_id > 0)
{
if ($delivery_order['agency_id'] != $agency_id)
{
sys_msg($_LANG['priv_error']);
}
/* 取當前辦事處信息 */
$sql = "SELECT agency_name FROM " . $ecs->table('agency') . " WHERE agency_id = '$agency_id' LIMIT 0, 1";
$agency_name = $db->getOne($sql);
$delivery_order['agency_name'] = $agency_name;
}
/* 取得用户名 */
if ($delivery_order['user_id'] > 0)
{
$user = user_info($delivery_order['user_id']);
if (!empty($user))
{
$delivery_order['user_name'] = $user['user_name'];
}
}
/* 取得區域名 */
$sql = "SELECT concat(IFNULL(c.region_name, ''), ' ', IFNULL(p.region_name, ''), " .
"' ', IFNULL(t.region_name, ''), ' ', IFNULL(d.region_name, '')) AS region " .
"FROM " . $ecs->table('order_info') . " AS o " .
"LEFT JOIN " . $ecs->table('region') . " AS c ON o.country = c.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS p ON o.province = p.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS t ON o.city = t.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS d ON o.district = d.region_id " .
"WHERE o.order_id = '" . $delivery_order['order_id'] . "'";
$delivery_order['region'] = $db->getOne($sql);
/* 是否保價 */
$order['insure_yn'] = empty($order['insure_fee']) ? 0 : 1;
/* 取得發貨單產品 */
$goods_sql = "SELECT *
FROM " . $ecs->table('delivery_goods') . "
WHERE delivery_id = " . $delivery_order['delivery_id'];
$goods_list = $GLOBALS['db']->getAll($goods_sql);
/* 是否存在實體產品 */
$exist_real_goods = 0;
if ($goods_list)
{
foreach ($goods_list as $value)
{
if ($value['is_real'])
{
$exist_real_goods++;
}
}
}
/* 取得訂單操作記錄 */
$act_list = array();
$sql = "SELECT * FROM " . $ecs->table('order_action') . " WHERE order_id = '" . $delivery_order['order_id'] . "' AND action_place = 1 ORDER BY log_time DESC,action_id DESC";
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
$row['order_status'] = $_LANG['os'][$row['order_status']];
$row['pay_status'] = $_LANG['ps'][$row['pay_status']];
$row['shipping_status'] = ($row['shipping_status'] == SS_SHIPPED_ING) ? $_LANG['ss_admin'][SS_SHIPPED_ING] : $_LANG['ss'][$row['shipping_status']];
$row['action_time'] = local_date($_CFG['time_format'], $row['log_time']);
$act_list[] = $row;
}
/*同步發貨*/
/*判斷支付方式是否支付寶*/
$alipay = false;
$order = order_info($delivery_order['order_id']); //根據訂單ID查詢訂單信息返回數組$order
$payment = payment_info($order['pay_id']); //取得支付方式信息
/* 定義當前時間 */
define('GMTIME_UTC', gmtime()); // 獲取 UTC 時間戳
/* 根據發貨單id查詢發貨單信息 */
if (!empty($delivery_id))
{
$delivery_order = delivery_order_info($delivery_id);
}
else
{
die('order does not exist');
}
/* 查詢訂單信息 */
$order = order_info($order_id);
/* 檢查此單發貨產品庫存缺貨情況 */
$virtual_goods = array();
$delivery_stock_sql = "SELECT DG.goods_id, DG.is_real, DG.product_id, SUM(DG.send_number) AS sums, IF(DG.product_id > 0, P.product_number, G.goods_number) AS storage, G.goods_name, DG.send_number
FROM " . $GLOBALS['ecs']->table('delivery_goods') . " AS DG, " . $GLOBALS['ecs']->table('goods') . " AS G, " . $GLOBALS['ecs']->table('products') . " AS P
WHERE DG.goods_id = G.goods_id
AND DG.delivery_id = '$delivery_id'
AND DG.product_id = P.product_id
GROUP BY DG.product_id ";
$delivery_stock_result = $GLOBALS['db']->getAll($delivery_stock_sql);
/* 如果產品存在規格就查詢規格,如果不存在規格按產品庫存查詢 */
if(!empty($delivery_stock_result))
{
foreach ($delivery_stock_result as $value)
{
if (($value['sums'] > $value['storage'] || $value['storage'] <= 0) && (($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP) || ($_CFG['use_storage'] == '0' && $value['is_real'] == 0)))
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=delivery_info&delivery_id=' . $delivery_id);
sys_msg(sprintf($_LANG['act_good_vacancy'], $value['goods_name']), 1, $links);
break;
}
/* 虛擬產品列表 virtual_card*/
if ($value['is_real'] == 0)
{
$virtual_goods[] = array(
'goods_id' => $value['goods_id'],
'goods_name' => $value['goods_name'],
'num' => $value['send_number']
);
}
}
}
else
{
$delivery_stock_sql = "SELECT DG.goods_id, DG.is_real, SUM(DG.send_number) AS sums, G.goods_number, G.goods_name, DG.send_number
FROM " . $GLOBALS['ecs']->table('delivery_goods') . " AS DG, " . $GLOBALS['ecs']->table('goods') . " AS G
WHERE DG.goods_id = G.goods_id
AND DG.delivery_id = '$delivery_id'
GROUP BY DG.goods_id ";
$delivery_stock_result = $GLOBALS['db']->getAll($delivery_stock_sql);
foreach ($delivery_stock_result as $value)
{
if (($value['sums'] > $value['goods_number'] || $value['goods_number'] <= 0) && (($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP) || ($_CFG['use_storage'] == '0' && $value['is_real'] == 0)))
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=delivery_info&delivery_id=' . $delivery_id);
sys_msg(sprintf($_LANG['act_good_vacancy'], $value['goods_name']), 1, $links);
break;
}
/* 虛擬產品列表 virtual_card*/
if ($value['is_real'] == 0)
{
$virtual_goods[] = array(
'goods_id' => $value['goods_id'],
'goods_name' => $value['goods_name'],
'num' => $value['send_number'],
);
}
}
}
/* 發貨 */
/* 處理虛擬卡 產品(虛貨) */
if (is_array($virtual_goods) && count($virtual_goods) > 0)
{
foreach ($virtual_goods as $virtual_value)
{
virtual_card_shipping($virtual_value,$order['order_sn'], $msg, 'split');
}
}
/* 如果使用庫存,且發貨時減庫存,則修改庫存 */
if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP)
{
foreach ($delivery_stock_result as $value)
{
/* 產品(實貨)、超級禮包(實貨) */
if ($value['is_real'] != 0)
{
//(貨品)
if (!empty($value['product_id']))
{
$minus_stock_sql = "UPDATE " . $GLOBALS['ecs']->table('products') . "
SET product_number = product_number - " . $value['sums'] . "
WHERE product_id = " . $value['product_id'];
$GLOBALS['db']->query($minus_stock_sql, 'SILENT');
}
$minus_stock_sql = "UPDATE " . $GLOBALS['ecs']->table('goods') . "
SET goods_number = goods_number - " . $value['sums'] . "
WHERE goods_id = " . $value['goods_id'];
$GLOBALS['db']->query($minus_stock_sql, 'SILENT');
}
}
}
/* 修改發貨單信息 */
$invoice_no = trim($invoice_no);
$_delivery['invoice_no'] = $invoice_no;
$_delivery['status'] = 0; // 0為已發貨
$query = $db->autoExecute($ecs->table('delivery_order'), $_delivery, 'UPDATE', "delivery_id = $delivery_id", 'SILENT');
if (!$query)
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['delivery_sn'] . $_LANG['detail'], 'href' => 'order.php?act=delivery_info&delivery_id=' . $delivery_id);
sys_msg($_LANG['act_false'], 1, $links);
}
/* 標記訂單為已確認 "已發貨" */
/* 更新發貨時間 */
$order_finish = get_all_delivery_finish($order_id);
$shipping_status = ($order_finish == 1) ? SS_SHIPPED : SS_SHIPPED_PART;
$arr['shipping_status'] = $shipping_status;
$arr['shipping_time'] = GMTIME_UTC; // 發貨時間
$arr['invoice_no'] = trim($order['invoice_no'] . '<br>' . $invoice_no, '<br>');
update_order($order_id, $arr);
/* 發貨單發貨記錄log */
order_action($order['order_sn'], OS_CONFIRMED, $shipping_status, $order['pay_status'], $action_note, null, 1);
/* 如果當前訂單已經全部發貨 */
if ($order_finish)
{
/* 如果訂單用户不為空,計算積分,併發給用户;發紅包 */
if ($order['user_id'] > 0)
{
/* 取得用户信息 */
$user = user_info($order['user_id']);
/* 計算併發放積分 */
$integral = integral_to_give($order);
log_account_change($order['user_id'], 0, 0, intval($integral['rank_points']), intval($integral['custom_points']), sprintf($_LANG['order_gift_integral'], $order['order_sn']));
//echo "<pre>";
//print_r($order);exit;
/* 發放紅包 */
send_order_bonus($order_id);
}
/* 發送郵件 */
$cfg = $_CFG['send_ship_email'];
if ($cfg == '1')
{
$order['invoice_no'] = $invoice_no;
$tpl = get_mail_template('deliver_notice');
$smarty->assign('order', $order);
$smarty->assign('send_time', local_date($_CFG['time_format']));
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('send_date', local_date($_CFG['date_format']));
$smarty->assign('sent_date', local_date($_CFG['date_format']));
$smarty->assign('confirm_url', $ecs->url() . 'receive.php?id=' . $order['order_id'] . '&con=' . rawurlencode($order['consignee']));
$smarty->assign('send_msg_url',$ecs->url() . 'user.php?act=message_list&order_id=' . $order['order_id']);
$content = $smarty->fetch('str:' . $tpl['template_content']);
if (!send_mail($order['consignee'], $order['email'], $tpl['template_subject'], $content, $tpl['is_html']))
{
$msg = $_LANG['send_mail_fail'];
}
}
/* 商家發貨時給客户發送短信提醒 */
if ($_CFG['ecsdxt_order_shipped'] == '1' && $order['mobile'] != '')
{
require_once(ROOT_PATH . 'includes/lib_sms.php');
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('order_sn', $order['order_sn']);
$smarty->assign('time', local_date($GLOBALS['_LANG']['sms_time_format']));
$content = $smarty->fetch('str:' . $_CFG['ecsdxt_order_shipped_value']);
$ret = sendsms($order['mobile'], $content);
}
/* 微信發送發貨通知*/
$wxch_order_name = 'order';
$sql ="select autoload from ". $GLOBALS['ecs']->table('weixin_order') ." where order_name='order'";
$autoload=$db->getOne($sql);
if($autoload=="yes"){
include_once(ROOT_PATH . 'mobile/wxch_notice.php');
weixin_notice($order,'order');
}
}
/* 清除緩存 */
clear_cache_files();
/* 操作成功 */
$links[] = array('text' => $_LANG['09_delivery_order'], 'href' => 'order.php?act=delivery_list');
$links[] = array('text' => $_LANG['delivery_sn'] . $_LANG['detail'], 'href' => 'order.php?act=delivery_info&delivery_id=' . $delivery_id);
sys_msg($_LANG['act_ok'], 0, $links);
}
}
/*------------------------------------------------------ */
//-- end一鍵發貨 增加 by www.mb5.com.cn
/*------------------------------------------------------ */
/* 付款 */
elseif (isset($_POST['pay']))
{
/* 檢查權限 */
admin_priv('order_ps_edit');
$require_note = $_CFG['order_pay_note'] == 1;
$action = $_LANG['op_pay'];
$operation = 'pay';
}
/* 未付款 */
elseif (isset($_POST['unpay']))
{
/* 檢查權限 */
admin_priv('order_ps_edit');
$require_note = $_CFG['order_unpay_note'] == 1;
$order = order_info($order_id);
if ($order['money_paid'] > 0)
{
$show_refund = true;
}
$anonymous = $order['user_id'] == 0;
$action = $_LANG['op_unpay'];
$operation = 'unpay';
}
/* 配貨 */
elseif (isset($_POST['prepare']))
{
$require_note = false;
$action = $_LANG['op_prepare'];
$operation = 'prepare';
}
/* 分單 */
elseif (isset($_POST['ship']))
{
/* 查詢:檢查權限 */
admin_priv('order_ss_edit');
$order_id = intval(trim($order_id));
$action_note = trim($action_note);
/* 查詢根據訂單id查詢訂單信息 */
if (!empty($order_id))
{
$order = order_info($order_id);
}
else
{
die('order does not exist');
}
/* 查詢:根據訂單是否完成 檢查權限 */
if (order_finished($order))
{
admin_priv('order_view_finished');
}
else
{
admin_priv('order_view');
}
/* 查詢:如果管理員屬於某個辦事處,檢查該訂單是否也屬於這個辦事處 */
$sql = "SELECT agency_id FROM " . $ecs->table('admin_user') . " WHERE user_id = '$_SESSION[admin_id]'";
$agency_id = $db->getOne($sql);
if ($agency_id > 0)
{
if ($order['agency_id'] != $agency_id)
{
sys_msg($_LANG['priv_error'], 0);
}
}
/* 查詢:取得用户名 */
if ($order['user_id'] > 0)
{
$user = user_info($order['user_id']);
if (!empty($user))
{
$order['user_name'] = $user['user_name'];
}
}
/* 查詢:取得區域名 */
$sql = "SELECT concat(IFNULL(c.region_name, ''), ' ', IFNULL(p.region_name, ''), " .
"' ', IFNULL(t.region_name, ''), ' ', IFNULL(d.region_name, '')) AS region " .
"FROM " . $ecs->table('order_info') . " AS o " .
"LEFT JOIN " . $ecs->table('region') . " AS c ON o.country = c.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS p ON o.province = p.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS t ON o.city = t.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS d ON o.district = d.region_id " .
"WHERE o.order_id = '$order[order_id]'";
$order['region'] = $db->getOne($sql);
/* 查詢:其他處理 */
$order['order_time'] = local_date($_CFG['time_format'], $order['add_time']);
$order['invoice_no'] = $order['shipping_status'] == SS_UNSHIPPED || $order['shipping_status'] == SS_PREPARING ? $_LANG['ss'][SS_UNSHIPPED] : $order['invoice_no'];
/* 查詢:是否保價 */
$order['insure_yn'] = empty($order['insure_fee']) ? 0 : 1;
/* 查詢:是否存在實體產品 */
$exist_real_goods = exist_real_goods($order_id);
/* 查詢:取得訂單產品 */
$_goods = get_order_goods(array('order_id' => $order['order_id'], 'order_sn' =>$order['order_sn']));
$attr = $_goods['attr'];
$goods_list = $_goods['goods_list'];
unset($_goods);
/* 查詢:產品已發貨數量 此單可發貨數量 */
if ($goods_list)
{
foreach ($goods_list as $key=>$goods_value)
{
if (!$goods_value['goods_id'])
{
continue;
}
/* 超級禮包 */
if (($goods_value['extension_code'] == 'package_buy') && (count($goods_value['package_goods_list']) > 0))
{
$goods_list[$key]['package_goods_list'] = package_goods($goods_value['package_goods_list'], $goods_value['goods_number'], $goods_value['order_id'], $goods_value['extension_code'], $goods_value['goods_id']);
foreach ($goods_list[$key]['package_goods_list'] as $pg_key => $pg_value)
{
$goods_list[$key]['package_goods_list'][$pg_key]['readonly'] = '';
/* 使用庫存 是否缺貨 */
if ($pg_value['storage'] <= 0 && $_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP)
{
$goods_list[$key]['package_goods_list'][$pg_key]['send'] = $_LANG['act_good_vacancy'];
$goods_list[$key]['package_goods_list'][$pg_key]['readonly'] = 'readonly="readonly"';
}
/* 將已經全部發貨的產品設置為只讀 */
elseif ($pg_value['send'] <= 0)
{
$goods_list[$key]['package_goods_list'][$pg_key]['send'] = $_LANG['act_good_delivery'];
$goods_list[$key]['package_goods_list'][$pg_key]['readonly'] = 'readonly="readonly"';
}
}
}
else
{
$goods_list[$key]['sended'] = $goods_value['send_number'];
$goods_list[$key]['send'] = $goods_value['goods_number'] - $goods_value['send_number'];
$goods_list[$key]['readonly'] = '';
/* 是否缺貨 */
if ($goods_value['storage'] <= 0 && $_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP)
{
$goods_list[$key]['send'] = $_LANG['act_good_vacancy'];
$goods_list[$key]['readonly'] = 'readonly="readonly"';
}
elseif ($goods_list[$key]['send'] <= 0)
{
$goods_list[$key]['send'] = $_LANG['act_good_delivery'];
$goods_list[$key]['readonly'] = 'readonly="readonly"';
}
}
}
}
/* 模板賦值 */
$smarty->assign('order', $order);
$smarty->assign('exist_real_goods', $exist_real_goods);
$smarty->assign('goods_attr', $attr);
$smarty->assign('goods_list', $goods_list);
$smarty->assign('order_id', $order_id); // 訂單id
$smarty->assign('operation', 'split'); // 訂單id
$smarty->assign('action_note', $action_note); // 發貨操作信息
$suppliers_list = get_suppliers_list();
$suppliers_list_count = count($suppliers_list);
$smarty->assign('suppliers_name', suppliers_list_name()); // 取供貨商名
$smarty->assign('suppliers_list', ($suppliers_list_count == 0 ? 0 : $suppliers_list)); // 取供貨商列表
/* 顯示模板 */
$smarty->assign('ur_here', $_LANG['order_operate'] . $_LANG['op_split']);
assign_query_info();
$smarty->display('order_delivery_info.htm');
exit;
}
/* 未發貨 */
elseif (isset($_POST['unship']))
{
/* 檢查權限 */
admin_priv('order_ss_edit');
$require_note = $_CFG['order_unship_note'] == 1;
$action = $_LANG['op_unship'];
$operation = 'unship';
}
/* 收貨確認 */
elseif (isset($_POST['receive']))
{
$require_note = $_CFG['order_receive_note'] == 1;
$action = $_LANG['op_receive'];
$operation = 'receive';
}
/* 取消 */
elseif (isset($_POST['cancel']))
{
$require_note = $_CFG['order_cancel_note'] == 1;
$action = $_LANG['op_cancel'];
$operation = 'cancel';
$show_cancel_note = true;
$order = order_info($order_id);
if ($order['money_paid'] > 0)
{
$show_refund = true;
}
$anonymous = $order['user_id'] == 0;
}
/* 無效 */
elseif (isset($_POST['invalid']))
{
$require_note = $_CFG['order_invalid_note'] == 1;
$action = $_LANG['op_invalid'];
$operation = 'invalid';
}
/* 售後 */
elseif (isset($_POST['after_service']))
{
$require_note = true;
$action = $_LANG['op_after_service'];
$operation = 'after_service';
}
/* 退貨 */
elseif (isset($_POST['return']))
{
$require_note = $_CFG['order_return_note'] == 1;
$order = order_info($order_id);
if ($order['money_paid'] > 0)
{
$show_refund = true;
}
$anonymous = $order['user_id'] == 0;
$action = $_LANG['op_return'];
$operation = 'return';
}
/* 指派 */
elseif (isset($_POST['assign']))
{
/* 取得參數 */
$new_agency_id = isset($_POST['agency_id']) ? intval($_POST['agency_id']) : 0;
if ($new_agency_id == 0)
{
sys_msg($_LANG['js_languages']['pls_select_agency']);
}
/* 查詢訂單信息 */
$order = order_info($order_id);
/* 如果管理員屬於某個辦事處,檢查該訂單是否也屬於這個辦事處 */
$sql = "SELECT agency_id FROM " . $ecs->table('admin_user') . " WHERE user_id = '$_SESSION[admin_id]'";
$admin_agency_id = $db->getOne($sql);
if ($admin_agency_id > 0)
{
if ($order['agency_id'] != $admin_agency_id)
{
sys_msg($_LANG['priv_error']);
}
}
/* 修改訂單相關所屬的辦事處 */
if ($new_agency_id != $order['agency_id'])
{
$query_array = array('order_info', // 更改訂單表的供貨商ID
'delivery_order', // 更改訂單的發貨單供貨商ID
'back_order'// 更改訂單的退貨單供貨商ID
);
foreach ($query_array as $value)
{
$db->query("UPDATE " . $ecs->table($value) . " SET agency_id = '$new_agency_id' " .
"WHERE order_id = '$order_id'");
}
}
/* 操作成功 */
$links[] = array('href' => 'order.php?act=list&' . list_link_postfix(), 'text' => $_LANG['02_order_list']);
sys_msg($_LANG['act_ok'], 0, $links);
}
/* 訂單刪除 */
elseif (isset($_POST['remove']))
{
$require_note = false;
$operation = 'remove';
if (!$batch)
{
/* 檢查能否操作 */
$order = order_info($order_id);
$operable_list = operable_list($order);
if (!isset($operable_list['remove']))
{
die('Hacking attempt');
}
/* 刪除訂單 */
$db->query("DELETE FROM ".$ecs->table('order_info'). " WHERE order_id = '$order_id'");
$db->query("DELETE FROM ".$ecs->table('order_goods'). " WHERE order_id = '$order_id'");
$db->query("DELETE FROM ".$ecs->table('order_action'). " WHERE order_id = '$order_id'");
$action_array = array('delivery', 'back');
del_delivery($order_id, $action_array);
/* todo 記錄日誌 */
admin_log($order['order_sn'], 'remove', 'order');
/* 返回 */
sys_msg($_LANG['order_removed'], 0, array(array('href'=>'order.php?act=list&' . list_link_postfix(), 'text' => $_LANG['return_list'])));
}
}
/* 發貨單刪除 */
elseif (isset($_REQUEST['remove_invoice']))
{
// 刪除發貨單
$delivery_id=$_REQUEST['delivery_id'];
$delivery_id = is_array($delivery_id) ? $delivery_id : array($delivery_id);
foreach($delivery_id as $value_is)
{
$value_is = intval(trim($value_is));
// 查詢:發貨單信息
$delivery_order = delivery_order_info($value_is);
// 如果status不是退貨
if ($delivery_order['status'] != 1)
{
/* 處理退貨 */
delivery_return_goods($value_is, $delivery_order);
}
// 如果status是已發貨並且發貨單號不為空
if ($delivery_order['status'] == 0 && $delivery_order['invoice_no'] != '')
{
/* 更新:刪除訂單中的發貨單號 */
del_order_invoice_no($delivery_order['order_id'], $delivery_order['invoice_no']);
}
// 更新:刪除發貨單
$sql = "DELETE FROM ".$ecs->table('delivery_order'). " WHERE delivery_id = '$value_is'";
$db->query($sql);
}
/* 返回 */
sys_msg($_LANG['tips_delivery_del'], 0, array(array('href'=>'order.php?act=delivery_list' , 'text' => $_LANG['return_list'])));
}
/* 退貨單刪除 */
elseif (isset($_REQUEST['remove_back']))
{
$back_id = $_REQUEST['back_id'];
/* 刪除退貨單 */
if(is_array($back_id))
{
foreach ($back_id as $value_is)
{
$sql = "DELETE FROM ".$ecs->table('back_order'). " WHERE back_id = '$value_is'";
$db->query($sql);
}
}
else
{
$sql = "DELETE FROM ".$ecs->table('back_order'). " WHERE back_id = '$back_id'";
$db->query($sql);
}
/* 返回 */
sys_msg($_LANG['tips_back_del'], 0, array(array('href'=>'order.php?act=back_list' , 'text' => $_LANG['return_list'])));
}
/* 批量打印訂單 */
elseif (isset($_POST['print']))
{
if (empty($_POST['order_id']))
{
sys_msg($_LANG['pls_select_order']);
}
/* 賦值公用信息 */
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('shop_url', $ecs->url());
$smarty->assign('shop_address', $_CFG['shop_address']);
$smarty->assign('service_phone',$_CFG['service_phone']);
$smarty->assign('print_time', local_date($_CFG['time_format']));
$smarty->assign('action_user', $_SESSION['admin_name']);
$html = '';
$order_sn_list = explode(',', $_POST['order_id']);
foreach ($order_sn_list as $order_sn)
{
/* 取得訂單信息 */
$order = order_info(0, $order_sn);
if (empty($order))
{
continue;
}
/* 根據訂單是否完成檢查權限 */
if (order_finished($order))
{
if (!admin_priv('order_view_finished', '', false))
{
continue;
}
}
else
{
if (!admin_priv('order_view', '', false))
{
continue;
}
}
/* 如果管理員屬於某個辦事處,檢查該訂單是否也屬於這個辦事處 */
$sql = "SELECT agency_id FROM " . $ecs->table('admin_user') . " WHERE user_id = '$_SESSION[admin_id]'";
$agency_id = $db->getOne($sql);
if ($agency_id > 0)
{
if ($order['agency_id'] != $agency_id)
{
continue;
}
}
/* 取得用户名 */
if ($order['user_id'] > 0)
{
$user = user_info($order['user_id']);
if (!empty($user))
{
$order['user_name'] = $user['user_name'];
}
}
/* 取得區域名 */
$sql = "SELECT concat(IFNULL(c.region_name, ''), ' ', IFNULL(p.region_name, ''), " .
"' ', IFNULL(t.region_name, ''), ' ', IFNULL(d.region_name, '')) AS region " .
"FROM " . $ecs->table('order_info') . " AS o " .
"LEFT JOIN " . $ecs->table('region') . " AS c ON o.country = c.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS p ON o.province = p.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS t ON o.city = t.region_id " .
"LEFT JOIN " . $ecs->table('region') . " AS d ON o.district = d.region_id " .
"WHERE o.order_id = '$order[order_id]'";
$order['region'] = $db->getOne($sql);
/* 其他處理 */
$order['order_time'] = local_date($_CFG['time_format'], $order['add_time']);
$order['pay_time'] = $order['pay_time'] > 0 ?
local_date($_CFG['time_format'], $order['pay_time']) : $_LANG['ps'][PS_UNPAYED];
$order['shipping_time'] = $order['shipping_time'] > 0 ?
local_date($_CFG['time_format'], $order['shipping_time']) : $_LANG['ss'][SS_UNSHIPPED];
$order['status'] = $_LANG['os'][$order['order_status']] . ',' . $_LANG['ps'][$order['pay_status']] . ',' . $_LANG['ss'][$order['shipping_status']];
$order['invoice_no'] = $order['shipping_status'] == SS_UNSHIPPED || $order['shipping_status'] == SS_PREPARING ? $_LANG['ss'][SS_UNSHIPPED] : $order['invoice_no'];
/* 此訂單的發貨備註(此訂單的最後一條操作記錄) */
$sql = "SELECT action_note FROM " . $ecs->table('order_action').
" WHERE order_id = '$order[order_id]' AND shipping_status = 1 ORDER BY log_time DESC";
$order['invoice_note'] = $db->getOne($sql);
/* 參數賦值:訂單 */
$smarty->assign('order', $order);
/* 取得訂單產品 */
$goods_list = array();
$goods_attr = array();
$sql = "SELECT o.*, g.goods_number AS storage, o.goods_attr, IFNULL(b.brand_name, '') AS brand_name " .
"FROM " . $ecs->table('order_goods') . " AS o ".
"LEFT JOIN " . $ecs->table('goods') . " AS g ON o.goods_id = g.goods_id " .
"LEFT JOIN " . $ecs->table('brand') . " AS b ON g.brand_id = b.brand_id " .
"WHERE o.order_id = '$order[order_id]' ";
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
/* 虛擬產品支持 */
if ($row['is_real'] == 0)
{
/* 取得語言項 */
$filename = ROOT_PATH . 'plugins/' . $row['extension_code'] . '/languages/common_' . $_CFG['lang'] . '.php';
if (file_exists($filename))
{
include_once($filename);
if (!empty($_LANG[$row['extension_code'].'_link']))
{
$row['goods_name'] = $row['goods_name'] . sprintf($_LANG[$row['extension_code'].'_link'], $row['goods_id'], $order['order_sn']);
}
}
}
$row['formated_subtotal'] = price_format($row['goods_price'] * $row['goods_number']);
$row['formated_goods_price'] = price_format($row['goods_price']);
$goods_attr[] = explode(' ', trim($row['goods_attr'])); //將產品屬性拆分為一個數組
$goods_list[] = $row;
}
$attr = array();
$arr = array();
foreach ($goods_attr AS $index => $array_val)
{
foreach ($array_val AS $value)
{
$arr = explode(':', $value);//以 : 號將屬性拆開
$attr[$index][] = @array('name' => $arr[0], 'value' => $arr[1]);
}
}
$smarty->assign('goods_attr', $attr);
$smarty->assign('goods_list', $goods_list);
$smarty->template_dir = '../' . DATA_DIR;
$html .= $smarty->fetch('order_print.html') .
'<div style="PAGE-BREAK-AFTER:always"></div>';
}
echo $html;
exit;
}
/* 去發貨 */
elseif (isset($_POST['to_delivery']))
{
$url = 'order.php?act=delivery_list&order_sn='.$_REQUEST['order_sn'];
ecs_header("Location: $url\n");
exit;
}
/* 直接處理還是跳到詳細頁面 */
if (($require_note && $action_note == '') || isset($show_invoice_no) || isset($show_refund))
{
/* 模板賦值 */
$smarty->assign('require_note', $require_note); // 是否要求填寫備註
$smarty->assign('action_note', $action_note); // 備註
$smarty->assign('show_cancel_note', isset($show_cancel_note)); // 是否顯示取消原因
$smarty->assign('show_invoice_no', isset($show_invoice_no)); // 是否顯示發貨單號
$smarty->assign('show_refund', isset($show_refund)); // 是否顯示退款
$smarty->assign('anonymous', isset($anonymous) ? $anonymous : true); // 是否匿名
$smarty->assign('order_id', $order_id); // 訂單id
$smarty->assign('batch', $batch); // 是否批處理
$smarty->assign('operation', $operation); // 操作
/* 顯示模板 */
$smarty->assign('ur_here', $_LANG['order_operate'] . $action);
assign_query_info();
$smarty->display('order_operate.htm');
}
else
{
/* 直接處理 */
if (!$batch)
{
/* 一個訂單 */
ecs_header("Location: order.php?act=operate_post&order_id=" . $order_id .
"&operation=" . $operation . "&action_note=" . urlencode($action_note) . "\n");
exit;
}
else
{
/* 多個訂單 */
ecs_header("Location: order.php?act=batch_operate_post&order_id=" . $order_id .
"&operation=" . $operation . "&action_note=" . urlencode($action_note) . "\n");
exit;
}
}
}
/*------------------------------------------------------ */
//-- 操作訂單狀態(處理批量提交)
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'batch_operate_post')
{
/* 檢查權限 */
admin_priv('order_os_edit');
/* 取得參數 */
$order_id = $_REQUEST['order_id']; // 訂單id逗號格開的多個訂單id
$operation = $_REQUEST['operation']; // 訂單操作
$action_note= $_REQUEST['action_note']; // 操作備註
$order_id_list = explode(',', $order_id);
/* 初始化處理的訂單sn */
$sn_list = array();
$sn_not_list = array();
/* 確認 */
if ('confirm' == $operation)
{
foreach($order_id_list as $id_order)
{
$sql = "SELECT * FROM " . $ecs->table('order_info') .
" WHERE order_sn = '$id_order'" .
" AND order_status = '" . OS_UNCONFIRMED . "'";
$order = $db->getRow($sql);
if($order)
{
/* 檢查能否操作 */
$operable_list = operable_list($order);
if (!isset($operable_list[$operation]))
{
$sn_not_list[] = $id_order;
continue;
}
$order_id = $order['order_id'];
/* 標記訂單為已確認 */
update_order($order_id, array('order_status' => OS_CONFIRMED, 'confirm_time' => gmtime()));
update_order_amount($order_id);
/* 記錄log */
order_action($order['order_sn'], OS_CONFIRMED, SS_UNSHIPPED, PS_UNPAYED, $action_note);
/* 發送郵件 */
if ($_CFG['send_confirm_email'] == '1')
{
$tpl = get_mail_template('order_confirm');
$order['formated_add_time'] = local_date($GLOBALS['_CFG']['time_format'], $order['add_time']);
$smarty->assign('order', $order);
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('send_date', local_date($_CFG['date_format']));
$smarty->assign('sent_date', local_date($_CFG['date_format']));
$content = $smarty->fetch('str:' . $tpl['template_content']);
send_mail($order['consignee'], $order['email'], $tpl['template_subject'], $content, $tpl['is_html']);
}
$sn_list[] = $order['order_sn'];
}
else
{
$sn_not_list[] = $id_order;
}
}
$sn_str = $_LANG['confirm_order'];
}
/* 無效 */
elseif ('invalid' == $operation)
{
foreach($order_id_list as $id_order)
{
$sql = "SELECT * FROM " . $ecs->table('order_info') .
" WHERE order_sn = $id_order" . order_query_sql('unpay_unship');
$order = $db->getRow($sql);
if($order)
{
/* 檢查能否操作 */
$operable_list = operable_list($order);
if (!isset($operable_list[$operation]))
{
$sn_not_list[] = $id_order;
continue;
}
$order_id = $order['order_id'];
/* 標記訂單為“無效” */
update_order($order_id, array('order_status' => OS_INVALID));
/* 記錄log */
order_action($order['order_sn'], OS_INVALID, SS_UNSHIPPED, PS_UNPAYED, $action_note);
/* 如果使用庫存,且下訂單時減庫存,則增加庫存 */
if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_PLACE)
{
change_order_goods_storage($order_id, false, SDT_PLACE);
}
/* 發送郵件 */
if ($_CFG['send_invalid_email'] == '1')
{
$tpl = get_mail_template('order_invalid');
$smarty->assign('order', $order);
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('send_date', local_date($_CFG['date_format']));
$smarty->assign('sent_date', local_date($_CFG['date_format']));
$content = $smarty->fetch('str:' . $tpl['template_content']);
send_mail($order['consignee'], $order['email'], $tpl['template_subject'], $content, $tpl['is_html']);
}
/* 退還用户餘額、積分、紅包 */
return_user_surplus_integral_bonus($order);
$sn_list[] = $order['order_sn'];
}
else
{
$sn_not_list[] = $id_order;
}
}
$sn_str = $_LANG['invalid_order'];
}
elseif ('cancel' == $operation)
{
foreach($order_id_list as $id_order)
{
$sql = "SELECT * FROM " . $ecs->table('order_info') .
" WHERE order_sn = $id_order" . order_query_sql('unpay_unship');
$order = $db->getRow($sql);
if($order)
{
/* 檢查能否操作 */
$operable_list = operable_list($order);
if (!isset($operable_list[$operation]))
{
$sn_not_list[] = $id_order;
continue;
}
$order_id = $order['order_id'];
/* 標記訂單為“取消”,記錄取消原因 */
$cancel_note = trim($_REQUEST['cancel_note']);
update_order($order_id, array('order_status' => OS_CANCELED, 'to_buyer' => $cancel_note));
/* 記錄log */
order_action($order['order_sn'], OS_CANCELED, $order['shipping_status'], PS_UNPAYED, $action_note);
/* 如果使用庫存,且下訂單時減庫存,則增加庫存 */
if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_PLACE)
{
change_order_goods_storage($order_id, false, SDT_PLACE);
}
/* 發送郵件 */
if ($_CFG['send_cancel_email'] == '1')
{
$tpl = get_mail_template('order_cancel');
$smarty->assign('order', $order);
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('send_date', local_date($_CFG['date_format']));
$smarty->assign('sent_date', local_date($_CFG['date_format']));
$content = $smarty->fetch('str:' . $tpl['template_content']);
send_mail($order['consignee'], $order['email'], $tpl['template_subject'], $content, $tpl['is_html']);
}
/* 退還用户餘額、積分、紅包 */
return_user_surplus_integral_bonus($order);
$sn_list[] = $order['order_sn'];
}
else
{
$sn_not_list[] = $id_order;
}
}
$sn_str = $_LANG['cancel_order'];
}
elseif ('remove' == $operation)
{
foreach ($order_id_list as $id_order)
{
/* 檢查能否操作 */
$order = order_info('', $id_order);
$operable_list = operable_list($order);
if (!isset($operable_list['remove']))
{
$sn_not_list[] = $id_order;
continue;
}
/* 刪除訂單 */
$db->query("DELETE FROM ".$ecs->table('order_info'). " WHERE order_id = '$order[order_id]'");
$db->query("DELETE FROM ".$ecs->table('order_goods'). " WHERE order_id = '$order[order_id]'");
$db->query("DELETE FROM ".$ecs->table('order_action'). " WHERE order_id = '$order[order_id]'");
$action_array = array('delivery', 'back');
del_delivery($order['order_id'], $action_array);
/* todo 記錄日誌 */
admin_log($order['order_sn'], 'remove', 'order');
$sn_list[] = $order['order_sn'];
}
$sn_str = $_LANG['remove_order'];
}
else
{
die('invalid params');
}
/* 取得備註信息 */
// $action_note = $_REQUEST['action_note'];
if(empty($sn_not_list))
{
$sn_list = empty($sn_list) ? '' : $_LANG['updated_order'] . join($sn_list, ',');
$msg = $sn_list;
$links[] = array('text' => $_LANG['return_list'], 'href' => 'order.php?act=list&' . list_link_postfix());
sys_msg($msg, 0, $links);
}
else
{
$order_list_no_fail = array();
$sql = "SELECT * FROM " . $ecs->table('order_info') .
" WHERE order_sn " . db_create_in($sn_not_list);
$res = $db->query($sql);
while($row = $db->fetchRow($res))
{
$order_list_no_fail[$row['order_id']]['order_id'] = $row['order_id'];
$order_list_no_fail[$row['order_id']]['order_sn'] = $row['order_sn'];
$order_list_no_fail[$row['order_id']]['order_status'] = $row['order_status'];
$order_list_no_fail[$row['order_id']]['shipping_status'] = $row['shipping_status'];
$order_list_no_fail[$row['order_id']]['pay_status'] = $row['pay_status'];
$order_list_fail = '';
foreach(operable_list($row) as $key => $value)
{
if($key != $operation)
{
$order_list_fail .= $_LANG['op_' . $key] . ',';
}
}
$order_list_no_fail[$row['order_id']]['operable'] = $order_list_fail;
}
/* 模板賦值 */
$smarty->assign('order_info', $sn_str);
$smarty->assign('action_link', array('href' => 'order.php?act=list', 'text' => $_LANG['02_order_list']));
$smarty->assign('order_list', $order_list_no_fail);
/* 顯示模板 */
assign_query_info();
$smarty->display('order_operate_info.htm');
}
}
/*------------------------------------------------------ */
//-- 操作訂單狀態(處理提交)
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'operate_post')
{
/* 檢查權限 */
admin_priv('order_os_edit');
/* 取得參數 */
$order_id = intval(trim($_REQUEST['order_id'])); // 訂單id
$operation = $_REQUEST['operation']; // 訂單操作
/* 查詢訂單信息 */
$order = order_info($order_id);
/* 檢查能否操作 */
$operable_list = operable_list($order);
if (!isset($operable_list[$operation]))
{
die('Hacking attempt');
}
/* 取得備註信息 */
$action_note = $_REQUEST['action_note'];
/* 初始化提示信息 */
$msg = '';
/* 確認 */
if ('confirm' == $operation)
{
/* 標記訂單為已確認 */
update_order($order_id, array('order_status' => OS_CONFIRMED, 'confirm_time' => gmtime()));
update_order_amount($order_id);
/* 記錄log */
order_action($order['order_sn'], OS_CONFIRMED, SS_UNSHIPPED, PS_UNPAYED, $action_note);
/* 如果原來狀態不是“未確認”,且使用庫存,且下訂單時減庫存,則減少庫存 */
if ($order['order_status'] != OS_UNCONFIRMED && $_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_PLACE)
{
change_order_goods_storage($order_id, true, SDT_PLACE);
}
/* 發送郵件 */
$cfg = $_CFG['send_confirm_email'];
if ($cfg == '1')
{
$tpl = get_mail_template('order_confirm');
$smarty->assign('order', $order);
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('send_date', local_date($_CFG['date_format']));
$smarty->assign('sent_date', local_date($_CFG['date_format']));
$content = $smarty->fetch('str:' . $tpl['template_content']);
if (!send_mail($order['consignee'], $order['email'], $tpl['template_subject'], $content, $tpl['is_html']))
{
$msg = $_LANG['send_mail_fail'];
}
}
}
/* 付款 */
elseif ('pay' == $operation)
{
/* 檢查權限 */
admin_priv('order_ps_edit');
/* 標記訂單為已確認、已付款,更新付款時間和已支付金額,如果是貨到付款,同時修改訂單為“收貨確認” */
if ($order['order_status'] != OS_CONFIRMED)
{
$arr['order_status'] = OS_CONFIRMED;
$arr['confirm_time'] = gmtime();
}
$arr['pay_status'] = PS_PAYED;
$arr['pay_time'] = gmtime();
$arr['money_paid'] = $order['money_paid'] + $order['order_amount'];
$arr['order_amount']= 0;
$payment = payment_info($order['pay_id']);
if ($payment['is_cod'])
{
$arr['shipping_status'] = SS_RECEIVED;
$order['shipping_status'] = SS_RECEIVED;
}
update_order($order_id, $arr);
/* 記錄log */
order_action($order['order_sn'], OS_CONFIRMED, $order['shipping_status'], PS_PAYED, $action_note);
}
/* 設為未付款 */
elseif ('unpay' == $operation)
{
/* 檢查權限 */
admin_priv('order_ps_edit');
/* 標記訂單為未付款,更新付款時間和已付款金額 */
$arr = array(
'pay_status' => PS_UNPAYED,
'pay_time' => 0,
'money_paid' => 0,
'order_amount' => $order['money_paid']
);
update_order($order_id, $arr);
/* todo 處理退款 */
$refund_type = @$_REQUEST['refund'];
$refund_note = @$_REQUEST['refund_note'];
order_refund($order, $refund_type, $refund_note);
/* 記錄log */
order_action($order['order_sn'], OS_CONFIRMED, SS_UNSHIPPED, PS_UNPAYED, $action_note);
}
/* 配貨 */
elseif ('prepare' == $operation)
{
/* 標記訂單為已確認,配貨中 */
if ($order['order_status'] != OS_CONFIRMED)
{
$arr['order_status'] = OS_CONFIRMED;
$arr['confirm_time'] = gmtime();
}
$arr['shipping_status'] = SS_PREPARING;
update_order($order_id, $arr);
/* 記錄log */
order_action($order['order_sn'], OS_CONFIRMED, SS_PREPARING, $order['pay_status'], $action_note);
/* 清除緩存 */
clear_cache_files();
/* 商家配貨時給客户發送短信提醒 */
if ($_CFG['ecsdxt_order_picking'] == '1' && $order['mobile'] != '')
{
require_once(ROOT_PATH . 'includes/lib_sms.php');
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('order_sn', $order['order_sn']);
$smarty->assign('time', local_date($GLOBALS['_LANG']['sms_time_format']));
$content = $smarty->fetch('str:' . $_CFG['ecsdxt_order_picking_value']);
$ret = sendsms($order['mobile'], $content);
}
}
/* 分單確認 */
elseif ('split' == $operation)
{
/* 檢查權限 */
admin_priv('order_ss_edit');
/* 定義當前時間 */
define('GMTIME_UTC', gmtime()); // 獲取 UTC 時間戳
/* 獲取表單提交數據 */
$suppliers_id = isset($_REQUEST['suppliers_id']) ? intval(trim($_REQUEST['suppliers_id'])) : '0';
array_walk($_REQUEST['delivery'], 'trim_array_walk');
$delivery = $_REQUEST['delivery'];
array_walk($_REQUEST['send_number'], 'trim_array_walk');
array_walk($_REQUEST['send_number'], 'intval_array_walk');
$send_number = $_REQUEST['send_number'];
$action_note = isset($_REQUEST['action_note']) ? trim($_REQUEST['action_note']) : '';
$delivery['user_id'] = intval($delivery['user_id']);
$delivery['country'] = intval($delivery['country']);
$delivery['province'] = intval($delivery['province']);
$delivery['city'] = intval($delivery['city']);
$delivery['district'] = intval($delivery['district']);
$delivery['agency_id'] = intval($delivery['agency_id']);
$delivery['insure_fee'] = floatval($delivery['insure_fee']);
$delivery['shipping_fee'] = floatval($delivery['shipping_fee']);
$delivery['address'] = '';
/* 訂單是否已全部分單檢查 */
if ($order['order_status'] == OS_SPLITED)
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
sys_msg(sprintf($_LANG['order_splited_sms'], $order['order_sn'],
$_LANG['os'][OS_SPLITED], $_LANG['ss'][SS_SHIPPED_ING], $GLOBALS['_CFG']['shop_name']), 1, $links);
}
/* 取得訂單產品 */
$_goods = get_order_goods(array('order_id' => $order_id, 'order_sn' => $delivery['order_sn']));
$goods_list = $_goods['goods_list'];
/* 檢查此單發貨數量填寫是否正確 合併計算相同產品和貨品 */
// if (!empty($send_number) && !empty($goods_list))
// {
// $goods_no_package = array();
// foreach ($goods_list as $key => $value)
// {
// /* 去除 此單發貨數量 等於 0 的產品 */
// if (!isset($value['package_goods_list']) || !is_array($value['package_goods_list']))
// {
// // 如果是貨品則鍵值為產品ID與貨品ID的組合
// $_key = empty($value['product_id']) ? $value['goods_id'] : ($value['goods_id'] . '_' . $value['product_id']);
// // 統計此單產品總髮貨數 合併計算相同ID產品或貨品的發貨數
// if (empty($goods_no_package[$_key]))
// {
// $goods_no_package[$_key] = $send_number[$value['rec_id']];
// }
// else
// {
// $goods_no_package[$_key] += $send_number[$value['rec_id']];
// }
// //去除
// if ($send_number[$value['rec_id']] <= 0)
// {
// unset($send_number[$value['rec_id']], $goods_list[$key]);
// continue;
// }
// }
// else
// {
// /* 組合超值禮包信息 */
// $goods_list[$key]['package_goods_list'] = package_goods($value['package_goods_list'], $value['goods_number'], $value['order_id'], $value['extension_code'], $value['goods_id']);
// /* 超值禮包 */
// foreach ($value['package_goods_list'] as $pg_key => $pg_value)
// {
// // 如果是貨品則鍵值為產品ID與貨品ID的組合
// $_key = empty($pg_value['product_id']) ? $pg_value['goods_id'] : ($pg_value['goods_id'] . '_' . $pg_value['product_id']);
// //統計此單產品總髮貨數 合併計算相同ID產品的發貨數
// if (empty($goods_no_package[$_key]))
// {
// $goods_no_package[$_key] = $send_number[$value['rec_id']][$pg_value['g_p']];
// }
// //否則已經存在此鍵值
// else
// {
// $goods_no_package[$_key] += $send_number[$value['rec_id']][$pg_value['g_p']];
// }
// //去除
// if ($send_number[$value['rec_id']][$pg_value['g_p']] <= 0)
// {
// unset($send_number[$value['rec_id']][$pg_value['g_p']], $goods_list[$key]['package_goods_list'][$pg_key]);
// }
// }
// if (count($goods_list[$key]['package_goods_list']) <= 0)
// {
// unset($send_number[$value['rec_id']], $goods_list[$key]);
// continue;
// }
// }
// /* 發貨數量與總量不符 */
// if (!isset($value['package_goods_list']) || !is_array($value['package_goods_list']))
// {
// $sended = order_delivery_num($order_id, $value['goods_id'], $value['product_id']);
// if (($value['goods_number'] - $sended - $send_number[$value['rec_id']]) < 0)
// {
// /* 操作失敗 */
// $links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
// sys_msg($_LANG['act_ship_num'], 1, $links);
// }
// }
// else
// {
// /* 超值禮包 */
// foreach ($goods_list[$key]['package_goods_list'] as $pg_key => $pg_value)
// {
// if (($pg_value['order_send_number'] - $pg_value['sended'] - $send_number[$value['rec_id']][$pg_value['g_p']]) < 0)
// {
// /* 操作失敗 */
// $links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
// sys_msg($_LANG['act_ship_num'], 1, $links);
// }
// }
// }
// }
// }
/* 對上一步處理結果進行判斷 兼容 上一步判斷為假情況的處理 */
if (empty($send_number) || empty($goods_list))
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
sys_msg($_LANG['act_false'], 1, $links);
}
/* 檢查此單發貨產品庫存缺貨情況 */
/* $goods_list已經過處理 超值禮包中產品庫存已取得 */
$virtual_goods = array();
$package_virtual_goods = array();
foreach ($goods_list as $key => $value)
{
// 產品(超值禮包)
if ($value['extension_code'] == 'package_buy')
{
foreach ($value['package_goods_list'] as $pg_key => $pg_value)
{
if ($pg_value['goods_number'] < $goods_no_package[$pg_value['g_p']] && (($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP) || ($_CFG['use_storage'] == '0' && $pg_value['is_real'] == 0)))
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
sys_msg(sprintf($_LANG['act_good_vacancy'], $pg_value['goods_name']), 1, $links);
}
/* 產品(超值禮包) 虛擬產品列表 package_virtual_goods*/
if ($pg_value['is_real'] == 0)
{
$package_virtual_goods[] = array(
'goods_id' => $pg_value['goods_id'],
'goods_name' => $pg_value['goods_name'],
'num' => $send_number[$value['rec_id']][$pg_value['g_p']]
);
}
}
}
// 產品(虛貨)
elseif ($value['extension_code'] == 'virtual_card' || $value['is_real'] == 0)
{
$sql = "SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('virtual_card') . " WHERE goods_id = '" . $value['goods_id'] . "' AND is_saled = 0 ";
$num = $GLOBALS['db']->GetOne($sql);
if (($num < $goods_no_package[$value['goods_id']]) && !($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_PLACE))
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
sys_msg(sprintf($GLOBALS['_LANG']['virtual_card_oos'] . '【' . $value['goods_name'] . '】'), 1, $links);
}
/* 虛擬產品列表 virtual_card*/
if ($value['extension_code'] == 'virtual_card')
{
$virtual_goods[$value['extension_code']][] = array('goods_id' => $value['goods_id'], 'goods_name' => $value['goods_name'], 'num' => $send_number[$value['rec_id']]);
}
}
// 產品(實貨)、(貨品)
else
{
//如果是貨品則鍵值為產品ID與貨品ID的組合
$_key = empty($value['product_id']) ? $value['goods_id'] : ($value['goods_id'] . '_' . $value['product_id']);
/* (實貨) */
if (empty($value['product_id']))
{
$sql = "SELECT goods_number FROM " . $GLOBALS['ecs']->table('goods') . " WHERE goods_id = '" . $value['goods_id'] . "' LIMIT 0,1";
}
/* (貨品) */
else
{
$sql = "SELECT product_number
FROM " . $GLOBALS['ecs']->table('products') ."
WHERE goods_id = '" . $value['goods_id'] . "'
AND product_id = '" . $value['product_id'] . "'
LIMIT 0,1";
}
$num = $GLOBALS['db']->GetOne($sql);
if (($num < $goods_no_package[$_key]) && $_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP)
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
sys_msg(sprintf($_LANG['act_good_vacancy'], $value['goods_name']), 1, $links);
}
}
}
/* 生成發貨單 */
/* 獲取發貨單號和流水號 */
$delivery['delivery_sn'] = get_delivery_sn();
$delivery_sn = $delivery['delivery_sn'];
/* 獲取當前操作員 */
$delivery['action_user'] = $_SESSION['admin_name'];
/* 獲取發貨單生成時間 */
$delivery['update_time'] = GMTIME_UTC;
$delivery_time = $delivery['update_time'];
$sql ="select add_time from ". $GLOBALS['ecs']->table('order_info') ." WHERE order_sn = '" . $delivery['order_sn'] . "'";
$delivery['add_time'] = $GLOBALS['db']->GetOne($sql);
/* 獲取發貨單所屬供應商 */
$delivery['suppliers_id'] = $suppliers_id;
/* 設置默認值 */
$delivery['status'] = 2; // 正常
$delivery['order_id'] = $order_id;
/* 過濾字段項 */
$filter_fileds = array(
'order_sn', 'add_time', 'user_id', 'how_oos', 'shipping_id', 'shipping_fee',
'consignee', 'address', 'country', 'province', 'city', 'district', 'sign_building',
'email', 'zipcode', 'tel', 'mobile', 'best_time', 'postscript', 'insure_fee',
'agency_id', 'delivery_sn', 'action_user', 'update_time',
'suppliers_id', 'status', 'order_id', 'shipping_name'
);
$_delivery = array();
foreach ($filter_fileds as $value)
{
$_delivery[$value] = $delivery[$value];
}
/* 發貨單入庫 */
$query = $db->autoExecute($ecs->table('delivery_order'), $_delivery, 'INSERT', '', 'SILENT');
$delivery_id = $db->insert_id();
if ($delivery_id)
{
$delivery_goods = array();
//發貨單產品入庫
if (!empty($goods_list))
{
foreach ($goods_list as $value)
{
// 產品(實貨)(虛貨)
if (empty($value['extension_code']) || $value['extension_code'] == 'virtual_card')
{
$delivery_goods = array('delivery_id' => $delivery_id,
'goods_id' => $value['goods_id'],
'product_id' => $value['product_id'],
'product_sn' => $value['product_sn'],
'goods_id' => $value['goods_id'],
'goods_name' => addslashes($value['goods_name']),
'brand_name' => addslashes($value['brand_name']),
'goods_sn' => $value['goods_sn'],
'send_number' => $send_number[$value['rec_id']],
'parent_id' => 0,
'is_real' => $value['is_real'],
'goods_attr' => addslashes($value['goods_attr'])
);
/* 如果是貨品 */
if (!empty($value['product_id']))
{
$delivery_goods['product_id'] = $value['product_id'];
}
$query = $db->autoExecute($ecs->table('delivery_goods'), $delivery_goods, 'INSERT', '', 'SILENT');
}
// 產品(超值禮包)
elseif ($value['extension_code'] == 'package_buy')
{
foreach ($value['package_goods_list'] as $pg_key => $pg_value)
{
$delivery_pg_goods = array('delivery_id' => $delivery_id,
'goods_id' => $pg_value['goods_id'],
'product_id' => $pg_value['product_id'],
'product_sn' => $pg_value['product_sn'],
'goods_name' => $pg_value['goods_name'],
'brand_name' => '',
'goods_sn' => $pg_value['goods_sn'],
'send_number' => $send_number[$value['rec_id']][$pg_value['g_p']],
'parent_id' => $value['goods_id'], // 禮包ID
'extension_code' => $value['extension_code'], // 禮包
'is_real' => $pg_value['is_real']
);
$query = $db->autoExecute($ecs->table('delivery_goods'), $delivery_pg_goods, 'INSERT', '', 'SILENT');
}
}
}
}
}
else
{
/* 操作失敗 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
sys_msg($_LANG['act_false'], 1, $links);
}
unset($filter_fileds, $delivery, $_delivery, $order_finish);
/* 定單信息更新處理 */
if (true)
{
/* 定單信息 */
$_sended = & $send_number;
foreach ($_goods['goods_list'] as $key => $value)
{
if ($value['extension_code'] != 'package_buy')
{
unset($_goods['goods_list'][$key]);
}
}
foreach ($goods_list as $key => $value)
{
if ($value['extension_code'] == 'package_buy')
{
unset($goods_list[$key]);
}
}
$_goods['goods_list'] = $goods_list + $_goods['goods_list'];
unset($goods_list);
/* 更新訂單的虛擬卡 產品(虛貨) */
$_virtual_goods = isset($virtual_goods['virtual_card']) ? $virtual_goods['virtual_card'] : '';
update_order_virtual_goods($order_id, $_sended, $_virtual_goods);
/* 更新訂單的非虛擬產品信息 即:產品(實貨)(貨品)、產品(超值禮包)*/
update_order_goods($order_id, $_sended, $_goods['goods_list']);
/* 標記訂單為已確認 “發貨中” */
/* 更新發貨時間 */
$order_finish = get_order_finish($order_id);
$shipping_status = SS_SHIPPED_ING;
if ($order['order_status'] != OS_CONFIRMED && $order['order_status'] != OS_SPLITED && $order['order_status'] != OS_SPLITING_PART)
{
$arr['order_status'] = OS_CONFIRMED;
$arr['confirm_time'] = GMTIME_UTC;
}
$arr['order_status'] = $order_finish ? OS_SPLITED : OS_SPLITING_PART; // 全部分單、部分分單
$arr['shipping_status'] = $shipping_status;
update_order($order_id, $arr);
}
/* 記錄log */
order_action($order['order_sn'], $arr['order_status'], $shipping_status, $order['pay_status'], $action_note);
/* 清除緩存 */
clear_cache_files();
}
/* 設為未發貨 */
elseif ('unship' == $operation)
{
/* 檢查權限 */
admin_priv('order_ss_edit');
/* 標記訂單為“未發貨”,更新發貨時間, 訂單狀態為“確認” */
update_order($order_id, array('shipping_status' => SS_UNSHIPPED, 'shipping_time' => 0, 'invoice_no' => '', 'order_status' => OS_CONFIRMED));
/* 記錄log */
order_action($order['order_sn'], $order['order_status'], SS_UNSHIPPED, $order['pay_status'], $action_note);
/* 如果訂單用户不為空,計算積分,並退回 */
if ($order['user_id'] > 0)
{
/* 取得用户信息 */
$user = user_info($order['user_id']);
/* 計算並退回積分 */
$integral = integral_to_give($order);
log_account_change($order['user_id'], 0, 0, (-1) * intval($integral['rank_points']), (-1) * intval($integral['custom_points']), sprintf($_LANG['return_order_gift_integral'], $order['order_sn']));
/* todo 計算並退回紅包 */
return_order_bonus($order_id);
}
/* 如果使用庫存,則增加庫存 */
if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP)
{
change_order_goods_storage($order['order_id'], false, SDT_SHIP);
}
/* 刪除發貨單 */
del_order_delivery($order_id);
/* 將訂單的產品發貨數量更新為 0 */
$sql = "UPDATE " . $GLOBALS['ecs']->table('order_goods') . "
SET send_number = 0
WHERE order_id = '$order_id'";
$GLOBALS['db']->query($sql, 'SILENT');
/* 清除緩存 */
clear_cache_files();
}
/* 收貨確認 */
elseif ('receive' == $operation)
{
/* 標記訂單為“收貨確認”,如果是貨到付款,同時修改訂單為已付款 */
$arr = array('shipping_status' => SS_RECEIVED);
$payment = payment_info($order['pay_id']);
if ($payment['is_cod'])
{
$arr['pay_status'] = PS_PAYED;
$order['pay_status'] = PS_PAYED;
}
update_order($order_id, $arr);
/* 記錄log */
order_action($order['order_sn'], $order['order_status'], SS_RECEIVED, $order['pay_status'], $action_note);
}
/* 取消 */
elseif ('cancel' == $operation)
{
/* 標記訂單為“取消”,記錄取消原因 */
$cancel_note = isset($_REQUEST['cancel_note']) ? trim($_REQUEST['cancel_note']) : '';
$arr = array(
'order_status' => OS_CANCELED,
'to_buyer' => $cancel_note,
'pay_status' => PS_UNPAYED,
'pay_time' => 0,
'money_paid' => 0,
'order_amount' => $order['money_paid']
);
update_order($order_id, $arr);
/* todo 處理退款 */
if ($order['money_paid'] > 0)
{
$refund_type = $_REQUEST['refund'];
$refund_note = $_REQUEST['refund_note'];
order_refund($order, $refund_type, $refund_note);
}
/* 記錄log */
order_action($order['order_sn'], OS_CANCELED, $order['shipping_status'], PS_UNPAYED, $action_note);
/* 如果使用庫存,且下訂單時減庫存,則增加庫存 */
if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_PLACE)
{
change_order_goods_storage($order_id, false, SDT_PLACE);
}
/* 退還用户餘額、積分、紅包 */
return_user_surplus_integral_bonus($order);
/* 發送郵件 */
$cfg = $_CFG['send_cancel_email'];
if ($cfg == '1')
{
$tpl = get_mail_template('order_cancel');
$smarty->assign('order', $order);
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('send_date', local_date($_CFG['date_format']));
$smarty->assign('sent_date', local_date($_CFG['date_format']));
$content = $smarty->fetch('str:' . $tpl['template_content']);
if (!send_mail($order['consignee'], $order['email'], $tpl['template_subject'], $content, $tpl['is_html']))
{
$msg = $_LANG['send_mail_fail'];
}
}
}
/* 設為無效 */
elseif ('invalid' == $operation)
{
/* 標記訂單為“無效”、“未付款” */
update_order($order_id, array('order_status' => OS_INVALID));
/* 記錄log */
order_action($order['order_sn'], OS_INVALID, $order['shipping_status'], PS_UNPAYED, $action_note);
/* 如果使用庫存,且下訂單時減庫存,則增加庫存 */
if ($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_PLACE)
{
change_order_goods_storage($order_id, false, SDT_PLACE);
}
/* 發送郵件 */
$cfg = $_CFG['send_invalid_email'];
if ($cfg == '1')
{
$tpl = get_mail_template('order_invalid');
$smarty->assign('order', $order);
$smarty->assign('shop_name', $_CFG['shop_name']);
$smarty->assign('send_date', local_date($_CFG['date_format']));
$smarty->assign('sent_date', local_date($_CFG['date_format']));
$content = $smarty->fetch('str:' . $tpl['template_content']);
if (!send_mail($order['consignee'], $order['email'], $tpl['template_subject'], $content, $tpl['is_html']))
{
$msg = $_LANG['send_mail_fail'];
}
}
/* 退貨用户餘額、積分、紅包 */
return_user_surplus_integral_bonus($order);
}
/* 退貨 */
elseif ('return' == $operation)
{
/* 定義當前時間 */
define('GMTIME_UTC', gmtime()); // 獲取 UTC 時間戳
/* 過濾數據 */
$_REQUEST['refund'] = isset($_REQUEST['refund']) ? $_REQUEST['refund'] : '';
$_REQUEST['refund_note'] = isset($_REQUEST['refund_note']) ? $_REQUEST['refund'] : '';
/* 標記訂單為“退貨”、“未付款”、“未發貨” */
$arr = array('order_status' => OS_RETURNED,
'pay_status' => PS_UNPAYED,
'shipping_status' => SS_UNSHIPPED,
'money_paid' => 0,
'invoice_no' => '',
'order_amount' => $order['money_paid']);
update_order($order_id, $arr);
/* todo 處理退款 */
if ($order['pay_status'] != PS_UNPAYED)
{
$refund_type = $_REQUEST['refund'];
$refund_note = $_REQUEST['refund'];
order_refund($order, $refund_type, $refund_note);
}
/* 記錄log */
order_action($order['order_sn'], OS_RETURNED, SS_UNSHIPPED, PS_UNPAYED, $action_note);
/* 如果訂單用户不為空,計算積分,並退回 */
if ($order['user_id'] > 0)
{
/* 取得用户信息 */
$user = user_info($order['user_id']);
$sql = "SELECT goods_number, send_number FROM". $GLOBALS['ecs']->table('order_goods') . "
WHERE order_id = '".$order['order_id']."'";
$goods_num = $db->query($sql);
$goods_num = $db->fetchRow($goods_num);
if($goods_num['goods_number'] == $goods_num['send_number'])
{
/* 計算並退回積分 */
$integral = integral_to_give($order);
log_account_change($order['user_id'], 0, 0, (-1) * intval($integral['rank_points']), (-1) * intval($integral['custom_points']), sprintf($_LANG['return_order_gift_integral'], $order['order_sn']));
}
/* todo 計算並退回紅包 */
return_order_bonus($order_id);
}
/* 如果使用庫存,則增加庫存(不論何時減庫存都需要) */
if ($_CFG['use_storage'] == '1')
{
if ($_CFG['stock_dec_time'] == SDT_SHIP)
{
change_order_goods_storage($order['order_id'], false, SDT_SHIP);
}
elseif ($_CFG['stock_dec_time'] == SDT_PLACE)
{
change_order_goods_storage($order['order_id'], false, SDT_PLACE);
}
}
/* 退貨用户餘額、積分、紅包 */
return_user_surplus_integral_bonus($order);
/* 獲取當前操作員 */
$delivery['action_user'] = $_SESSION['admin_name'];
/* 添加退貨記錄 */
$delivery_list = array();
$sql_delivery = "SELECT *
FROM " . $ecs->table('delivery_order') . "
WHERE status IN (0, 2)
AND order_id = " . $order['order_id'];
$delivery_list = $GLOBALS['db']->getAll($sql_delivery);
if ($delivery_list)
{
foreach ($delivery_list as $list)
{
$sql_back = "INSERT INTO " . $ecs->table('back_order') . " (delivery_sn, order_sn, order_id, add_time, shipping_id, user_id, action_user, consignee, address, Country, province, City, district, sign_building, Email,Zipcode, Tel, Mobile, best_time, postscript, how_oos, insure_fee, shipping_fee, update_time, suppliers_id, return_time, agency_id, invoice_no) VALUES ";
$sql_back .= " ( '" . $list['delivery_sn'] . "', '" . $list['order_sn'] . "',
'" . $list['order_id'] . "', '" . $list['add_time'] . "',
'" . $list['shipping_id'] . "', '" . $list['user_id'] . "',
'" . $delivery['action_user'] . "', '" . $list['consignee'] . "',
'" . $list['address'] . "', '" . $list['country'] . "', '" . $list['province'] . "',
'" . $list['city'] . "', '" . $list['district'] . "', '" . $list['sign_building'] . "',
'" . $list['email'] . "', '" . $list['zipcode'] . "', '" . $list['tel'] . "',
'" . $list['mobile'] . "', '" . $list['best_time'] . "', '" . $list['postscript'] . "',
'" . $list['how_oos'] . "', '" . $list['insure_fee'] . "',
'" . $list['shipping_fee'] . "', '" . $list['update_time'] . "',
'" . $list['suppliers_id'] . "', '" . GMTIME_UTC . "',
'" . $list['agency_id'] . "', '" . $list['invoice_no'] . "'
)";
$GLOBALS['db']->query($sql_back, 'SILENT');
$back_id = $GLOBALS['db']->insert_id();
$sql_back_goods = "INSERT INTO " . $ecs->table('back_goods') . " (back_id, goods_id, product_id, product_sn, goods_name,goods_sn, is_real, send_number, goods_attr)
SELECT '$back_id', goods_id, product_id, product_sn, goods_name, goods_sn, is_real, send_number, goods_attr
FROM " . $ecs->table('delivery_goods') . "
WHERE delivery_id = " . $list['delivery_id'];
$GLOBALS['db']->query($sql_back_goods, 'SILENT');
}
}
/* 修改訂單的發貨單狀態為退貨 */
$sql_delivery = "UPDATE " . $ecs->table('delivery_order') . "
SET status = 1
WHERE status IN (0, 2)
AND order_id = " . $order['order_id'];
$GLOBALS['db']->query($sql_delivery, 'SILENT');
/* 將訂單的產品發貨數量更新為 0 */
$sql = "UPDATE " . $GLOBALS['ecs']->table('order_goods') . "
SET send_number = 0
WHERE order_id = '$order_id'";
$GLOBALS['db']->query($sql, 'SILENT');
/* 清除緩存 */
clear_cache_files();
}
elseif ('after_service' == $operation)
{
/* 記錄log */
order_action($order['order_sn'], $order['order_status'], $order['shipping_status'], $order['pay_status'], '[' . $_LANG['op_after_service'] . '] ' . $action_note);
}
else
{
die('invalid params');
}
/* 操作成功 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
sys_msg($_LANG['act_ok'] . $msg, 0, $links);
}
elseif ($_REQUEST['act'] == 'json')
{
include_once(ROOT_PATH . 'includes/cls_json.php');
$json = new JSON();
$func = $_REQUEST['func'];
if ($func == 'get_goods_info')
{
/* 取得產品信息 */
$goods_id = $_REQUEST['goods_id'];
$sql = "SELECT goods_id, c.cat_name, goods_sn, goods_name, b.brand_name, " .
"goods_number, market_price, shop_price, promote_price, " .
"promote_start_date, promote_end_date, goods_brief, goods_type, is_promote " .
"FROM " . $ecs->table('goods') . " AS g " .
"LEFT JOIN " . $ecs->table('brand') . " AS b ON g.brand_id = b.brand_id " .
"LEFT JOIN " . $ecs->table('category') . " AS c ON g.cat_id = c.cat_id " .
" WHERE goods_id = '$goods_id'";
$goods = $db->getRow($sql);
$today = gmtime();
$goods['goods_price'] = ($goods['is_promote'] == 1 &&
$goods['promote_start_date'] <= $today && $goods['promote_end_date'] >= $today) ?
$goods['promote_price'] : $goods['shop_price'];
/* 取得客戶價格 */
$sql = "SELECT p.user_price, r.rank_name " .
"FROM " . $ecs->table('member_price') . " AS p, " .
$ecs->table('user_rank') . " AS r " .
"WHERE p.user_rank = r.rank_id " .
"AND p.goods_id = '$goods_id' ";
$goods['user_price'] = $db->getAll($sql);
/* 取得產品屬性 */
$sql = "SELECT a.attr_id, a.attr_name, g.goods_attr_id, g.attr_value, g.attr_price, a.attr_input_type, a.attr_type " .
"FROM " . $ecs->table('goods_attr') . " AS g, " .
$ecs->table('attribute') . " AS a " .
"WHERE g.attr_id = a.attr_id " .
"AND g.goods_id = '$goods_id' ";
$goods['attr_list'] = array();
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
$goods['attr_list'][$row['attr_id']][] = $row;
}
$goods['attr_list'] = array_values($goods['attr_list']);
echo $json->encode($goods);
}
}
/*------------------------------------------------------ */
//-- 合併訂單
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'ajax_merge_order')
{
/* 檢查權限 */
admin_priv('order_os_edit');
include_once(ROOT_PATH . 'includes/cls_json.php');
$json = new JSON();
$from_order_sn = empty($_POST['from_order_sn']) ? '' : json_str_iconv(substr($_POST['from_order_sn'], 1));
$to_order_sn = empty($_POST['to_order_sn']) ? '' : json_str_iconv(substr($_POST['to_order_sn'], 1));
$m_result = merge_order($from_order_sn, $to_order_sn);
$result = array('error'=>0, 'content'=>'');
if ($m_result === true)
{
$result['message'] = $GLOBALS['_LANG']['act_ok'];
}
else
{
$result['error'] = 1;
$result['message'] = $m_result;
}
die($json->encode($result));
}
/*------------------------------------------------------ */
//-- 刪除訂單
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'remove_order')
{
/* 檢查權限 */
admin_priv('order_edit');
$order_id = intval($_REQUEST['id']);
/* 檢查權限 */
check_authz_json('order_edit');
/* 檢查訂單是否允許刪除操作 */
$order = order_info($order_id);
$operable_list = operable_list($order);
if (!isset($operable_list['remove']))
{
make_json_error('Hacking attempt');
exit;
}
$GLOBALS['db']->query("DELETE FROM ".$GLOBALS['ecs']->table('order_info'). " WHERE order_id = '$order_id'");
$GLOBALS['db']->query("DELETE FROM ".$GLOBALS['ecs']->table('order_goods'). " WHERE order_id = '$order_id'");
$GLOBALS['db']->query("DELETE FROM ".$GLOBALS['ecs']->table('order_action'). " WHERE order_id = '$order_id'");
$action_array = array('delivery', 'back');
del_delivery($order_id, $action_array);
if ($GLOBALS['db'] ->errno() == 0)
{
$url = 'order.php?act=query&' . str_replace('act=remove_order', '', $_SERVER['QUERY_STRING']);
ecs_header("Location: $url\n");
exit;
}
else
{
make_json_error($GLOBALS['db']->errorMsg());
}
}
/*------------------------------------------------------ */
//-- 根據關鍵字和id搜索用户
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'search_users')
{
include_once(ROOT_PATH . 'includes/cls_json.php');
$json = new JSON();
$id_name = empty($_GET['id_name']) ? '' : json_str_iconv(trim($_GET['id_name']));
$result = array('error'=>0, 'message'=>'', 'content'=>'');
if ($id_name != '')
{
$sql = "SELECT user_id, user_name FROM " . $GLOBALS['ecs']->table('users') .
" WHERE user_id LIKE '%" . mysql_like_quote($id_name) . "%'" .
" OR user_name LIKE '%" . mysql_like_quote($id_name) . "%'" .
" LIMIT 20";
$res = $GLOBALS['db']->query($sql);
$result['userlist'] = array();
while ($row = $GLOBALS['db']->fetchRow($res))
{
$result['userlist'][] = array('user_id' => $row['user_id'], 'user_name' => $row['user_name']);
}
}
else
{
$result['error'] = 1;
$result['message'] = 'NO KEYWORDS!';
}
die($json->encode($result));
}
/*------------------------------------------------------ */
//-- 根據關鍵字搜索產品
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'search_goods')
{
include_once(ROOT_PATH . 'includes/cls_json.php');
$json = new JSON();
$keyword = empty($_GET['keyword']) ? '' : json_str_iconv(trim($_GET['keyword']));
$result = array('error'=>0, 'message'=>'', 'content'=>'');
if ($keyword != '')
{
$sql = "SELECT goods_id, goods_name, goods_sn FROM " . $GLOBALS['ecs']->table('goods') .
" WHERE is_delete = 0" .
" AND is_on_sale = 1" .
" AND is_alone_sale = 1" .
" AND (goods_id LIKE '%" . mysql_like_quote($keyword) . "%'" .
" OR goods_name LIKE '%" . mysql_like_quote($keyword) . "%'" .
" OR goods_sn LIKE '%" . mysql_like_quote($keyword) . "%')" .
" LIMIT 20";
$res = $GLOBALS['db']->query($sql);
$result['goodslist'] = array();
while ($row = $GLOBALS['db']->fetchRow($res))
{
$result['goodslist'][] = array('goods_id' => $row['goods_id'], 'name' => $row['goods_id'] . ' ' . $row['goods_name'] . ' ' . $row['goods_sn']);
}
}
else
{
$result['error'] = 1;
$result['message'] = 'NO KEYWORDS';
}
die($json->encode($result));
}
/*------------------------------------------------------ */
//-- 編輯收貨單號
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'edit_invoice_no')
{
/* 檢查權限 */
check_authz_json('order_edit');
$no = empty($_POST['val']) ? 'N/A' : json_str_iconv(trim($_POST['val']));
$no = $no=='N/A' ? '' : $no;
$order_id = empty($_POST['id']) ? 0 : intval($_POST['id']);
if ($order_id == 0)
{
make_json_error('NO ORDER ID');
exit;
}
$sql = 'UPDATE ' . $GLOBALS['ecs']->table('order_info') . " SET invoice_no='$no' WHERE order_id = '$order_id'";
if ($GLOBALS['db']->query($sql))
{
if (empty($no))
{
make_json_result('N/A');
}
else
{
make_json_result(stripcslashes($no));
}
}
else
{
make_json_error($GLOBALS['db']->errorMsg());
}
}
/*------------------------------------------------------ */
//-- 編輯付款備註
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'edit_pay_note')
{
/* 檢查權限 */
check_authz_json('order_edit');
$no = empty($_POST['val']) ? 'N/A' : json_str_iconv(trim($_POST['val']));
$no = $no=='N/A' ? '' : $no;
$order_id = empty($_POST['id']) ? 0 : intval($_POST['id']);
if ($order_id == 0)
{
make_json_error('NO ORDER ID');
exit;
}
$sql = 'UPDATE ' . $GLOBALS['ecs']->table('order_info') . " SET pay_note='$no' WHERE order_id = '$order_id'";
if ($GLOBALS['db']->query($sql))
{
if (empty($no))
{
make_json_result('N/A');
}
else
{
make_json_result(stripcslashes($no));
}
}
else
{
make_json_error($GLOBALS['db']->errorMsg());
}
}
/*------------------------------------------------------ */
//-- 獲取訂單產品信息
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'get_goods_info')
{
/* 取得訂單產品 */
$order_id = isset($_REQUEST['order_id'])?intval($_REQUEST['order_id']):0;
if (empty($order_id))
{
make_json_response('', 1, $_LANG['error_get_goods_info']);
}
$goods_list = array();
$goods_attr = array();
$sql = "SELECT o.*, g.goods_thumb, g.goods_number AS storage, o.goods_attr, IFNULL(b.brand_name, '') AS brand_name " .
"FROM " . $ecs->table('order_goods') . " AS o ".
"LEFT JOIN " . $ecs->table('goods') . " AS g ON o.goods_id = g.goods_id " .
"LEFT JOIN " . $ecs->table('brand') . " AS b ON g.brand_id = b.brand_id " .
"WHERE o.order_id = '{$order_id}' ";
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
/* 虛擬產品支持 */
if ($row['is_real'] == 0)
{
/* 取得語言項 */
$filename = ROOT_PATH . 'plugins/' . $row['extension_code'] . '/languages/common_' . $_CFG['lang'] . '.php';
if (file_exists($filename))
{
include_once($filename);
if (!empty($_LANG[$row['extension_code'].'_link']))
{
$row['goods_name'] = $row['goods_name'] . sprintf($_LANG[$row['extension_code'].'_link'], $row['goods_id'], $order['order_sn']);
}
}
}
$row['formated_subtotal'] = price_format($row['goods_price'] * $row['goods_number']);
$row['formated_goods_price'] = price_format($row['goods_price']);
$_goods_thumb = get_image_path($row['goods_id'], $row['goods_thumb'], true);
$_goods_thumb = (strpos($_goods_thumb, 'http://') === 0) ? $_goods_thumb : $ecs->url() . $_goods_thumb;
$row['goods_thumb'] = $_goods_thumb;
$goods_attr[] = explode(' ', trim($row['goods_attr'])); //將產品屬性拆分為一個數組
$goods_list[] = $row;
}
$attr = array();
$arr = array();
foreach ($goods_attr AS $index => $array_val)
{
foreach ($array_val AS $value)
{
$arr = explode(':', $value);//以 : 號將屬性拆開
$attr[$index][] = @array('name' => $arr[0], 'value' => $arr[1]);
}
}
$smarty->assign('goods_attr', $attr);
$smarty->assign('goods_list', $goods_list);
$str = $smarty->fetch('order_goods_info.htm');
$goods[] = array('order_id' => $order_id, 'str' => $str);
make_json_result($goods);
}
/**
* 取得狀態列表
* @param string $type 類型all | order | shipping | payment
*/
function get_status_list($type = 'all')
{
global $_LANG;
$list = array();
if ($type == 'all' || $type == 'order')
{
$pre = $type == 'all' ? 'os_' : '';
foreach ($_LANG['os'] AS $key => $value)
{
$list[$pre . $key] = $value;
}
}
if ($type == 'all' || $type == 'shipping')
{
$pre = $type == 'all' ? 'ss_' : '';
foreach ($_LANG['ss'] AS $key => $value)
{
$list[$pre . $key] = $value;
}
}
if ($type == 'all' || $type == 'payment')
{
$pre = $type == 'all' ? 'ps_' : '';
foreach ($_LANG['ps'] AS $key => $value)
{
$list[$pre . $key] = $value;
}
}
return $list;
}
/**
* 退回餘額、積分、紅包取消、無效、退貨時把訂單使用餘額、積分、紅包設為0
* @param array $order 訂單信息
*/
function return_user_surplus_integral_bonus($order)
{
/* 處理餘額、積分、紅包 */
if ($order['user_id'] > 0 && $order['surplus'] > 0)
{
$surplus = $order['money_paid'] < 0 ? $order['surplus'] + $order['money_paid'] : $order['surplus'];
log_account_change($order['user_id'], $surplus, 0, 0, 0, sprintf($GLOBALS['_LANG']['return_order_surplus'], $order['order_sn']));
$GLOBALS['db']->query("UPDATE ". $GLOBALS['ecs']->table('order_info') . " SET `order_amount` = '0' WHERE `order_id` =". $order['order_id']);
}
if ($order['user_id'] > 0 && $order['integral'] > 0)
{
log_account_change($order['user_id'], 0, 0, 0, $order['integral'], sprintf($GLOBALS['_LANG']['return_order_integral'], $order['order_sn']));
}
if ($order['bonus_id'] > 0)
{
unuse_bonus($order['bonus_id']);
}
/* 修改訂單 */
$arr = array(
'bonus_id' => 0,
'bonus' => 0,
'integral' => 0,
'integral_money' => 0,
'surplus' => 0
);
update_order($order['order_id'], $arr);
}
/**
* 更新訂單總金額
* @param int $order_id 訂單id
* @return bool
*/
function update_order_amount($order_id)
{
include_once(ROOT_PATH . 'includes/lib_order.php');
//更新訂單總金額
$sql = "UPDATE " . $GLOBALS['ecs']->table('order_info') .
" SET order_amount = " . order_due_field() .
" WHERE order_id = '$order_id' LIMIT 1";
return $GLOBALS['db']->query($sql);
}
/**
* 返回某個訂單可執行的操作列表,包括權限判斷
* @param array $order 訂單信息 order_status, shipping_status, pay_status
* @param bool $is_cod 支付方式是否貨到付款
* @return array 可執行的操作 confirm, pay, unpay, prepare, ship, unship, receive, cancel, invalid, return, drop
* 格式 array('confirm' => true, 'pay' => true)
*/
function operable_list($order)
{
/* 取得訂單狀態、發貨狀態、付款狀態 */
$os = $order['order_status'];
$ss = $order['shipping_status'];
$ps = $order['pay_status'];
/* 取得訂單操作權限 */
$actions = $_SESSION['action_list'];
if ($actions == 'all')
{
$priv_list = array('os' => true, 'ss' => true, 'ps' => true, 'edit' => true);
}
else
{
$actions = ',' . $actions . ',';
$priv_list = array(
'os' => strpos($actions, ',order_os_edit,') !== false,
'ss' => strpos($actions, ',order_ss_edit,') !== false,
'ps' => strpos($actions, ',order_ps_edit,') !== false,
'edit' => strpos($actions, ',order_edit,') !== false
);
}
/* 取得訂單支付方式是否貨到付款 */
$payment = payment_info($order['pay_id']);
$is_cod = $payment['is_cod'] == 1;
/* 根據狀態返回可執行操作 */
$list = array();
if (OS_UNCONFIRMED == $os)
{
/* 狀態:未確認 => 未付款、未發貨 */
if ($priv_list['os'])
{
$list['confirm'] = true; // 確認
$list['invalid'] = true; // 無效
$list['cancel'] = true; // 取消
if ($is_cod)
{
/* 貨到付款 */
if ($priv_list['ss'])
{
$list['prepare'] = true; // 配貨
$list['split'] = true; // 分單
}
}
else
{
/* 不是貨到付款 */
if ($priv_list['ps'])
{
$list['pay'] = true; // 付款
}
}
}
}
elseif (OS_CONFIRMED == $os || OS_SPLITED == $os || OS_SPLITING_PART == $os)
{
/* 狀態:已確認 */
if (PS_UNPAYED == $ps)
{
/* 狀態:已確認、未付款 */
if (SS_UNSHIPPED == $ss || SS_PREPARING == $ss)
{
/* 狀態:已確認、未付款、未發貨(或配貨中) */
if ($priv_list['os'])
{
$list['cancel'] = true; // 取消
$list['invalid'] = true; // 無效
}
if ($is_cod)
{
/* 貨到付款 */
if ($priv_list['ss'])
{
if (SS_UNSHIPPED == $ss)
{
$list['prepare'] = true; // 配貨
}
$list['split'] = true; // 分單
}
}
else
{
/* 不是貨到付款 */
if ($priv_list['ps'])
{
$list['pay'] = true; // 付款
}
}
}
/* 狀態:已確認、未付款、發貨中 */
elseif (SS_SHIPPED_ING == $ss || SS_SHIPPED_PART == $ss)
{
// 部分分單
if (OS_SPLITING_PART == $os)
{
$list['split'] = true; // 分單
}
$list['to_delivery'] = true; // 去發貨
}
else
{
/* 狀態:已確認、未付款、已發貨或已收貨 => 貨到付款 */
if ($priv_list['ps'])
{
$list['pay'] = true; // 付款
}
if ($priv_list['ss'])
{
if (SS_SHIPPED == $ss)
{
$list['receive'] = true; // 收貨確認
}
$list['unship'] = true; // 設為未發貨
if ($priv_list['os'])
{
$list['return'] = true; // 退貨
}
}
}
}
else
{
/* 狀態:已確認、已付款和付款中 */
if (SS_UNSHIPPED == $ss || SS_PREPARING == $ss)
{
/* 狀態:已確認、已付款和付款中、未發貨(配貨中) => 不是貨到付款 */
if ($priv_list['ss'])
{
if (SS_UNSHIPPED == $ss)
{
$list['prepare'] = true; // 配貨
}
$list['split'] = true; // 分單
}
if ($priv_list['ps'])
{
$list['unpay'] = true; // 設為未付款
if ($priv_list['os'])
{
$list['cancel'] = true; // 取消
}
}
}
/* 狀態:已確認、未付款、發貨中 */
elseif (SS_SHIPPED_ING == $ss || SS_SHIPPED_PART == $ss)
{
// 部分分單
if (OS_SPLITING_PART == $os)
{
$list['split'] = true; // 分單
}
$list['to_delivery'] = true; // 去發貨
}
else
{
/* 狀態:已確認、已付款和付款中、已發貨或已收貨 */
if ($priv_list['ss'])
{
if (SS_SHIPPED == $ss)
{
$list['receive'] = true; // 收貨確認
}
if (!$is_cod)
{
$list['unship'] = true; // 設為未發貨
}
}
if ($priv_list['ps'] && $is_cod)
{
$list['unpay'] = true; // 設為未付款
}
if ($priv_list['os'] && $priv_list['ss'] && $priv_list['ps'])
{
$list['return'] = true; // 退貨(包括退款)
}
}
}
}
elseif (OS_CANCELED == $os)
{
/* 狀態:取消 */
if ($priv_list['os'])
{
$list['confirm'] = true;
}
if ($priv_list['edit'])
{
$list['remove'] = true;
}
}
elseif (OS_INVALID == $os)
{
/* 狀態:無效 */
if ($priv_list['os'])
{
$list['confirm'] = true;
}
if ($priv_list['edit'])
{
$list['remove'] = true;
}
}
elseif (OS_RETURNED == $os)
{
/* 狀態:退貨 */
if ($priv_list['os'])
{
$list['confirm'] = true;
}
}
/* 修正發貨操作 */
if (!empty($list['split']))
{
/* 如果是團購活動且未處理成功,不能發貨 */
if ($order['extension_code'] == 'group_buy')
{
include_once(ROOT_PATH . 'includes/lib_goods.php');
$group_buy = group_buy_info(intval($order['extension_id']));
if ($group_buy['status'] != GBS_SUCCEED)
{
unset($list['split']);
unset($list['to_delivery']);
}
}
/* 如果部分發貨 不允許 取消 訂單 */
if (order_deliveryed($order['order_id']))
{
$list['return'] = true; // 退貨(包括退款)
unset($list['cancel']); // 取消
}
}
/* 售後 */
$list['after_service'] = true;
return $list;
}
/**
* 處理編輯訂單時訂單金額變動
* @param array $order 訂單信息
* @param array $msgs 提示信息
* @param array $links 鏈接信息
*/
function handle_order_money_change($order, &$msgs, &$links)
{
$order_id = $order['order_id'];
if ($order['pay_status'] == PS_PAYED || $order['pay_status'] == PS_PAYING)
{
/* 應付款金額 */
$money_dues = $order['order_amount'];
if ($money_dues > 0)
{
/* 修改訂單為未付款 */
update_order($order_id, array('pay_status' => PS_UNPAYED, 'pay_time' => 0));
$msgs[] = $GLOBALS['_LANG']['amount_increase'];
$links[] = array('text' => $GLOBALS['_LANG']['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
}
elseif ($money_dues < 0)
{
$anonymous = $order['user_id'] > 0 ? 0 : 1;
$msgs[] = $GLOBALS['_LANG']['amount_decrease'];
$links[] = array('text' => $GLOBALS['_LANG']['refund'], 'href' => 'order.php?act=process&func=load_refund&anonymous=' .
$anonymous . '&order_id=' . $order_id . '&refund_amount=' . abs($money_dues));
}
}
}
/**
* 獲取訂單列表信息
*
* @access public
* @param
*
* @return void
*/
function order_list()
{
$result = get_filter();
if ($result === false)
{
/* 過濾信息 */
$filter['order_sn'] = empty($_REQUEST['order_sn']) ? '' : trim($_REQUEST['order_sn']);
if (!empty($_GET['is_ajax']) && $_GET['is_ajax'] == 1)
{
$_REQUEST['consignee'] = json_str_iconv($_REQUEST['consignee']);
//$_REQUEST['address'] = json_str_iconv($_REQUEST['address']);
}
$filter['consignee'] = empty($_REQUEST['consignee']) ? '' : trim($_REQUEST['consignee']);
$filter['email'] = empty($_REQUEST['email']) ? '' : trim($_REQUEST['email']);
$filter['address'] = empty($_REQUEST['address']) ? '' : trim($_REQUEST['address']);
$filter['zipcode'] = empty($_REQUEST['zipcode']) ? '' : trim($_REQUEST['zipcode']);
$filter['tel'] = empty($_REQUEST['tel']) ? '' : trim($_REQUEST['tel']);
$filter['mobile'] = empty($_REQUEST['mobile']) ? 0 : intval($_REQUEST['mobile']);
$filter['country'] = empty($_REQUEST['country']) ? 0 : intval($_REQUEST['country']);
$filter['province'] = empty($_REQUEST['province']) ? 0 : intval($_REQUEST['province']);
$filter['city'] = empty($_REQUEST['city']) ? 0 : intval($_REQUEST['city']);
$filter['district'] = empty($_REQUEST['district']) ? 0 : intval($_REQUEST['district']);
$filter['shipping_id'] = empty($_REQUEST['shipping_id']) ? 0 : intval($_REQUEST['shipping_id']);
$filter['pay_id'] = empty($_REQUEST['pay_id']) ? 0 : intval($_REQUEST['pay_id']);
$filter['order_status'] = isset($_REQUEST['order_status']) ? intval($_REQUEST['order_status']) : -1;
$filter['shipping_status'] = isset($_REQUEST['shipping_status']) ? intval($_REQUEST['shipping_status']) : -1;
$filter['pay_status'] = isset($_REQUEST['pay_status']) ? intval($_REQUEST['pay_status']) : -1;
$filter['user_id'] = empty($_REQUEST['user_id']) ? 0 : intval($_REQUEST['user_id']);
$filter['user_name'] = empty($_REQUEST['user_name']) ? '' : trim($_REQUEST['user_name']);
$filter['composite_status'] = isset($_REQUEST['composite_status']) ? intval($_REQUEST['composite_status']) : -1;
$filter['group_buy_id'] = isset($_REQUEST['group_buy_id']) ? intval($_REQUEST['group_buy_id']) : 0;
//預售
$filter['pre_sale_id'] = isset($_REQUEST['pre_sale_id']) ? intval($_REQUEST['pre_sale_id']) : 0;
$filter['sort_by'] = empty($_REQUEST['sort_by']) ? 'add_time' : trim($_REQUEST['sort_by']);
$filter['sort_order'] = empty($_REQUEST['sort_order']) ? 'DESC' : trim($_REQUEST['sort_order']);
$filter['start_time'] = empty($_REQUEST['start_time']) ? '' : (strpos($_REQUEST['start_time'], '-') > 0 ? local_strtotime($_REQUEST['start_time']) : $_REQUEST['start_time']);
$filter['end_time'] = empty($_REQUEST['end_time']) ? '' : (strpos($_REQUEST['end_time'], '-') > 0 ? local_strtotime($_REQUEST['end_time']) : $_REQUEST['end_time']);
$where = 'WHERE 1 ';
if ($filter['order_sn'])
{
$where .= " AND o.order_sn LIKE '%" . mysql_like_quote($filter['order_sn']) . "%'";
}
if ($filter['consignee'])
{
$where .= " AND o.consignee LIKE '%" . mysql_like_quote($filter['consignee']) . "%'";
}
if ($filter['email'])
{
$where .= " AND o.email LIKE '%" . mysql_like_quote($filter['email']) . "%'";
}
if ($filter['address'])
{
$where .= " AND o.address LIKE '%" . mysql_like_quote($filter['address']) . "%'";
}
if ($filter['zipcode'])
{
$where .= " AND o.zipcode LIKE '%" . mysql_like_quote($filter['zipcode']) . "%'";
}
if ($filter['tel'])
{
$where .= " AND o.tel LIKE '%" . mysql_like_quote($filter['tel']) . "%'";
}
if ($filter['mobile'])
{
$where .= " AND o.mobile LIKE '%" .mysql_like_quote($filter['mobile']) . "%'";
}
if ($filter['country'])
{
$where .= " AND o.country = '$filter[country]'";
}
if ($filter['province'])
{
$where .= " AND o.province = '$filter[province]'";
}
if ($filter['city'])
{
$where .= " AND o.city = '$filter[city]'";
}
if ($filter['district'])
{
$where .= " AND o.district = '$filter[district]'";
}
if ($filter['shipping_id'])
{
$where .= " AND o.shipping_id = '$filter[shipping_id]'";
}
if ($filter['pay_id'])
{
$where .= " AND o.pay_id = '$filter[pay_id]'";
}
if ($filter['order_status'] != -1)
{
$where .= " AND o.order_status = '$filter[order_status]'";
}
if ($filter['shipping_status'] != -1)
{
$where .= " AND o.shipping_status = '$filter[shipping_status]'";
}
if ($filter['pay_status'] != -1)
{
$where .= " AND o.pay_status = '$filter[pay_status]'";
}
if ($filter['user_id'])
{
$where .= " AND o.user_id = '$filter[user_id]'";
}
if ($filter['user_name'])
{
$where .= " AND u.user_name LIKE '%" . mysql_like_quote($filter['user_name']) . "%'";
}
if ($filter['start_time'])
{
$where .= " AND o.add_time >= '$filter[start_time]'";
}
if ($filter['end_time'])
{
$where .= " AND o.add_time <= '$filter[end_time]'";
}
//綜合狀態
switch($filter['composite_status'])
{
case CS_AWAIT_PAY :
$where .= order_query_sql('await_pay');
break;
case CS_AWAIT_SHIP :
$where .= order_query_sql('await_ship');
break;
case CS_FINISHED :
$where .= order_query_sql('finished');
break;
case PS_PAYING :
if ($filter['composite_status'] != -1)
{
$where .= " AND o.pay_status = '$filter[composite_status]' ";
}
break;
case OS_SHIPPED_PART :
if ($filter['composite_status'] != -1)
{
$where .= " AND o.shipping_status = '$filter[composite_status]'-2 ";
}
break;
default:
if ($filter['composite_status'] != -1)
{
$where .= " AND o.order_status = '$filter[composite_status]' ";
}
}
/* 團購訂單 */
if ($filter['group_buy_id'])
{
$where .= " AND o.extension_code = 'group_buy' AND o.extension_id = '$filter[group_buy_id]' ";
}
/* 預售訂單 */
if ($filter['pre_sale_id'])
{
$where .= " AND o.extension_code = '" . PRE_SALE_CODE . "' AND o.extension_id = '$filter[pre_sale_id]' ";
}
/* 如果管理員屬於某個辦事處,只列出這個辦事處管轄的訂單 */
$sql = "SELECT agency_id FROM " . $GLOBALS['ecs']->table('admin_user') . " WHERE user_id = '$_SESSION[admin_id]'";
$agency_id = $GLOBALS['db']->getOne($sql);
if ($agency_id > 0)
{
$where .= " AND o.agency_id = '$agency_id' ";
}
/* 分頁大小 */
$filter['page'] = empty($_REQUEST['page']) || (intval($_REQUEST['page']) <= 0) ? 1 : intval($_REQUEST['page']);
if (isset($_REQUEST['page_size']) && intval($_REQUEST['page_size']) > 0)
{
$filter['page_size'] = intval($_REQUEST['page_size']);
}
elseif (isset($_COOKIE['ECSCP']['page_size']) && intval($_COOKIE['ECSCP']['page_size']) > 0)
{
$filter['page_size'] = intval($_COOKIE['ECSCP']['page_size']);
}
else
{
$filter['page_size'] = 15;
}
/* 記錄總數 */
if ($filter['user_name'])
{
$sql = "SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('order_info') . " AS o ,".
$GLOBALS['ecs']->table('users') . " AS u " . $where;
}
else
{
$sql = "SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('order_info') . " AS o ". $where;
}
$filter['record_count'] = $GLOBALS['db']->getOne($sql);
$filter['page_count'] = $filter['record_count'] > 0 ? ceil($filter['record_count'] / $filter['page_size']) : 1;
/* 查詢 */
$sql = "SELECT o.order_id, o.order_sn, o.add_time, o.order_status, o.shipping_status, o.order_amount, o.money_paid," .
"o.pay_status, o.consignee, o.address, o.email, o.tel, o.mobile, o.extension_code, o.extension_id, " .
"(" . order_amount_field('o.') . ") AS total_fee, " .
"IFNULL(u.user_name, '" .$GLOBALS['_LANG']['anonymous']. "') AS buyer ".
" FROM " . $GLOBALS['ecs']->table('order_info') . " AS o " .
" LEFT JOIN " .$GLOBALS['ecs']->table('users'). " AS u ON u.user_id=o.user_id ". $where .
" ORDER BY $filter[sort_by] $filter[sort_order] ".
" LIMIT " . ($filter['page'] - 1) * $filter['page_size'] . ",$filter[page_size]";
foreach (array('order_sn', 'consignee', 'email', 'address', 'zipcode', 'tel', 'user_name') AS $val)
{
$filter[$val] = stripslashes($filter[$val]);
}
set_filter($filter, $sql);
}
else
{
$sql = $result['sql'];
$filter = $result['filter'];
}
$row = $GLOBALS['db']->getAll($sql);
/* 格式話數據 */
foreach ($row AS $key => $value)
{
$row[$key]['formated_order_amount'] = price_format($value['order_amount']);
$row[$key]['formated_money_paid'] = price_format($value['money_paid']);
$row[$key]['formated_total_fee'] = price_format($value['total_fee']);
$row[$key]['short_order_time'] = local_date('Y-m-d H:i', $value['add_time']);
if ($value['order_status'] == OS_INVALID || $value['order_status'] == OS_CANCELED)
{
/* 如果該訂單為無效或取消則顯示刪除鏈接 */
$row[$key]['can_remove'] = 1;
}
else
{
$row[$key]['can_remove'] = 0;
}
}
$arr = array('orders' => $row, 'filter' => $filter, 'page_count' => $filter['page_count'], 'record_count' => $filter['record_count']);
return $arr;
}
/**
* 更新訂單對應的 pay_log
* 如果未支付修改支付金額否則生成新的支付log
* @param int $order_id 訂單id
*/
function update_pay_log($order_id)
{
$order_id = intval($order_id);
if ($order_id > 0)
{
$sql = "SELECT order_amount FROM " . $GLOBALS['ecs']->table('order_info') .
" WHERE order_id = '$order_id'";
$order_amount = $GLOBALS['db']->getOne($sql);
if (!is_null($order_amount))
{
$sql = "SELECT log_id FROM " . $GLOBALS['ecs']->table('pay_log') .
" WHERE order_id = '$order_id'" .
" AND order_type = '" . PAY_ORDER . "'" .
" AND is_paid = 0";
$log_id = intval($GLOBALS['db']->getOne($sql));
if ($log_id > 0)
{
/* 未付款,更新支付金額 */
$sql = "UPDATE " . $GLOBALS['ecs']->table('pay_log') .
" SET order_amount = '$order_amount' " .
"WHERE log_id = '$log_id' LIMIT 1";
}
else
{
/* 已付款生成新的pay_log */
$sql = "INSERT INTO " . $GLOBALS['ecs']->table('pay_log') .
" (order_id, order_amount, order_type, is_paid)" .
"VALUES('$order_id', '$order_amount', '" . PAY_ORDER . "', 0)";
}
$GLOBALS['db']->query($sql);
}
}
}
/**
* 取得供貨商列表
* @return array 二維數組
*/
function get_suppliers_list()
{
$sql = 'SELECT *
FROM ' . $GLOBALS['ecs']->table('suppliers') . '
WHERE is_check = 1
ORDER BY suppliers_name ASC';
$res = $GLOBALS['db']->getAll($sql);
if (!is_array($res))
{
$res = array();
}
return $res;
}
/**
* 取得訂單產品
* @param array $order 訂單數組
* @return array
*/
function get_order_goods($order)
{
$goods_list = array();
$goods_attr = array();
$sql = "SELECT o.*, g.suppliers_id AS suppliers_id,IF(o.product_id > 0, p.product_number, g.goods_number) AS storage, o.goods_attr, IFNULL(b.brand_name, '') AS brand_name, p.product_sn " .
"FROM " . $GLOBALS['ecs']->table('order_goods') . " AS o ".
"LEFT JOIN " . $GLOBALS['ecs']->table('products') . " AS p ON o.product_id = p.product_id " .
"LEFT JOIN " . $GLOBALS['ecs']->table('goods') . " AS g ON o.goods_id = g.goods_id " .
"LEFT JOIN " . $GLOBALS['ecs']->table('brand') . " AS b ON g.brand_id = b.brand_id " .
"WHERE o.order_id = '$order[order_id]' ";
$res = $GLOBALS['db']->query($sql);
while ($row = $GLOBALS['db']->fetchRow($res))
{
// 虛擬產品支持
if ($row['is_real'] == 0)
{
/* 取得語言項 */
$filename = ROOT_PATH . 'plugins/' . $row['extension_code'] . '/languages/common_' . $GLOBALS['_CFG']['lang'] . '.php';
if (file_exists($filename))
{
include_once($filename);
if (!empty($GLOBALS['_LANG'][$row['extension_code'].'_link']))
{
$row['goods_name'] = $row['goods_name'] . sprintf($GLOBALS['_LANG'][$row['extension_code'].'_link'], $row['goods_id'], $order['order_sn']);
}
}
}
$row['formated_subtotal'] = price_format($row['goods_price'] * $row['goods_number']);
$row['formated_goods_price'] = price_format($row['goods_price']);
$goods_attr[] = explode(' ', trim($row['goods_attr'])); //將產品屬性拆分為一個數組
if ($row['extension_code'] == 'package_buy')
{
$row['storage'] = '';
$row['brand_name'] = '';
$row['package_goods_list'] = get_package_goods_list($row['goods_id']);
}
//處理貨品id
$row['product_id'] = empty($row['product_id']) ? 0 : $row['product_id'];
$goods_list[] = $row;
}
$attr = array();
$arr = array();
foreach ($goods_attr AS $index => $array_val)
{
foreach ($array_val AS $value)
{
$arr = explode(':', $value);//以 : 號將屬性拆開
$attr[$index][] = @array('name' => $arr[0], 'value' => $arr[1]);
}
}
return array('goods_list' => $goods_list, 'attr' => $attr);
}
/**
* 取得禮包列表
* @param integer $package_id 訂單產品表禮包類產品id
* @return array
*/
function get_package_goods_list($package_id)
{
$sql = "SELECT pg.goods_id, g.goods_name, (CASE WHEN pg.product_id > 0 THEN p.product_number ELSE g.goods_number END) AS goods_number, p.goods_attr, p.product_id, pg.goods_number AS
order_goods_number, g.goods_sn, g.is_real, p.product_sn
FROM " . $GLOBALS['ecs']->table('package_goods') . " AS pg
LEFT JOIN " .$GLOBALS['ecs']->table('goods') . " AS g ON pg.goods_id = g.goods_id
LEFT JOIN " . $GLOBALS['ecs']->table('products') . " AS p ON pg.product_id = p.product_id
WHERE pg.package_id = '$package_id'";
$resource = $GLOBALS['db']->query($sql);
if (!$resource)
{
return array();
}
$row = array();
/* 生成結果數組 取存在貨品的產品id 組合產品id與貨品id */
$good_product_str = '';
while ($_row = $GLOBALS['db']->fetch_array($resource))
{
if ($_row['product_id'] > 0)
{
/* 取存產品id */
$good_product_str .= ',' . $_row['goods_id'];
/* 組合產品id與貨品id */
$_row['g_p'] = $_row['goods_id'] . '_' . $_row['product_id'];
}
else
{
/* 組合產品id與貨品id */
$_row['g_p'] = $_row['goods_id'];
}
//生成結果數組
$row[] = $_row;
}
$good_product_str = trim($good_product_str, ',');
/* 釋放空間 */
unset($resource, $_row, $sql);
/* 取產品屬性 */
if ($good_product_str != '')
{
$sql = "SELECT ga.goods_attr_id, ga.attr_value, ga.attr_price, a.attr_name
FROM " .$GLOBALS['ecs']->table('goods_attr'). " AS ga, " .$GLOBALS['ecs']->table('attribute'). " AS a
WHERE a.attr_id = ga.attr_id
AND a.attr_type = 1
AND goods_id IN ($good_product_str)";
$result_goods_attr = $GLOBALS['db']->getAll($sql);
$_goods_attr = array();
foreach ($result_goods_attr as $value)
{
$_goods_attr[$value['goods_attr_id']] = $value;
}
}
/* 過濾貨品 */
$format[0] = "%s:%s[%d] <br>";
$format[1] = "%s--[%d]";
foreach ($row as $key => $value)
{
if ($value['goods_attr'] != '')
{
$goods_attr_array = explode('|', $value['goods_attr']);
$goods_attr = array();
foreach ($goods_attr_array as $_attr)
{
$goods_attr[] = sprintf($format[0], $_goods_attr[$_attr]['attr_name'], $_goods_attr[$_attr]['attr_value'], $_goods_attr[$_attr]['attr_price']);
}
$row[$key]['goods_attr_str'] = implode('', $goods_attr);
}
$row[$key]['goods_name'] = sprintf($format[1], $value['goods_name'], $value['order_goods_number']);
}
return $row;
// $sql = "SELECT pg.goods_id, CONCAT(g.goods_name, ' -- [', pg.goods_number, ']') AS goods_name,
// g.goods_number, pg.goods_number AS order_goods_number, g.goods_sn, g.is_real " .
// "FROM " . $GLOBALS['ecs']->table('package_goods') . " AS pg, " .
// $GLOBALS['ecs']->table('goods') . " AS g " .
// "WHERE pg.package_id = '$package_id' " .
// "AND pg.goods_id = g.goods_id ";
// $row = $GLOBALS['db']->getAll($sql);
//
// return $row;
}
/**
* 訂單單個產品或貨品的已發貨數量
*
* @param int $order_id 訂單 id
* @param int $goods_id 產品 id
* @param int $product_id 貨品 id
*
* @return int
*/
function order_delivery_num($order_id, $goods_id, $product_id = 0)
{
$sql = 'SELECT SUM(G.send_number) AS sums
FROM ' . $GLOBALS['ecs']->table('delivery_goods') . ' AS G, ' . $GLOBALS['ecs']->table('delivery_order') . ' AS O
WHERE O.delivery_id = G.delivery_id
AND O.status = 0
AND O.order_id = ' . $order_id . '
AND G.extension_code <> "package_buy"
AND G.goods_id = ' . $goods_id;
$sql .= ($product_id > 0) ? " AND G.product_id = '$product_id'" : '';
$sum = $GLOBALS['db']->getOne($sql);
if (empty($sum))
{
$sum = 0;
}
return $sum;
}
/**
* 判斷訂單是否已發貨(含部分發貨)
* @param int $order_id 訂單 id
* @return int 1已發貨0未發貨
*/
function order_deliveryed($order_id)
{
$return_res = 0;
if (empty($order_id))
{
return $return_res;
}
$sql = 'SELECT COUNT(delivery_id)
FROM ' . $GLOBALS['ecs']->table('delivery_order') . '
WHERE order_id = \''. $order_id . '\'
AND status = 0';
$sum = $GLOBALS['db']->getOne($sql);
if ($sum)
{
$return_res = 1;
}
return $return_res;
}
/**
* 更新訂單產品信息
* @param int $order_id 訂單 id
* @param array $_sended Array(產品id => ‘此單發貨數量’)
* @param array $goods_list
* @return Bool
*/
function update_order_goods($order_id, $_sended, $goods_list = array())
{
if (!is_array($_sended) || empty($order_id))
{
return false;
}
foreach ($_sended as $key => $value)
{
// 超值禮包
if (is_array($value))
{
if (!is_array($goods_list))
{
$goods_list = array();
}
foreach ($goods_list as $goods)
{
if (($key != $goods['rec_id']) || (!isset($goods['package_goods_list']) || !is_array($goods['package_goods_list'])))
{
continue;
}
$goods['package_goods_list'] = package_goods($goods['package_goods_list'], $goods['goods_number'], $goods['order_id'], $goods['extension_code'], $goods['goods_id']);
$pg_is_end = true;
foreach ($goods['package_goods_list'] as $pg_key => $pg_value)
{
if ($pg_value['order_send_number'] != $pg_value['sended'])
{
$pg_is_end = false; // 此超值禮包,此產品未全部發貨
break;
}
}
// 超值禮包產品全部發貨後更新訂單產品庫存
if ($pg_is_end)
{
$sql = "UPDATE " . $GLOBALS['ecs']->table('order_goods') . "
SET send_number = goods_number
WHERE order_id = '$order_id'
AND goods_id = '" . $goods['goods_id'] . "' ";
$GLOBALS['db']->query($sql, 'SILENT');
}
}
}
// 產品(實貨)(貨品)
elseif (!is_array($value))
{
/* 檢查是否為產品(實貨)(貨品) */
foreach ($goods_list as $goods)
{
if ($goods['rec_id'] == $key && $goods['is_real'] == 1)
{
$sql = "UPDATE " . $GLOBALS['ecs']->table('order_goods') . "
SET send_number = send_number + $value
WHERE order_id = '$order_id'
AND rec_id = '$key' ";
$GLOBALS['db']->query($sql, 'SILENT');
break;
}
}
}
}
return true;
}
/**
* 更新訂單虛擬產品信息
* @param int $order_id 訂單 id
* @param array $_sended Array(產品id => ‘此單發貨數量’)
* @param array $virtual_goods 虛擬產品列表
* @return Bool
*/
function update_order_virtual_goods($order_id, $_sended, $virtual_goods)
{
if (!is_array($_sended) || empty($order_id))
{
return false;
}
if (empty($virtual_goods))
{
return true;
}
elseif (!is_array($virtual_goods))
{
return false;
}
foreach ($virtual_goods as $goods)
{
$sql = "UPDATE ".$GLOBALS['ecs']->table('order_goods'). "
SET send_number = send_number + '" . $goods['num'] . "'
WHERE order_id = '" . $order_id . "'
AND goods_id = '" . $goods['goods_id'] . "' ";
if (!$GLOBALS['db']->query($sql, 'SILENT'))
{
return false;
}
}
return true;
}
/**
* 訂單中的產品是否已經全部發貨
* @param int $order_id 訂單 id
* @return int 1全部發貨0未全部發貨
*/
function get_order_finish($order_id)
{
$return_res = 0;
if (empty($order_id))
{
return $return_res;
}
$sql = 'SELECT COUNT(rec_id)
FROM ' . $GLOBALS['ecs']->table('order_goods') . '
WHERE order_id = \'' . $order_id . '\'
AND goods_number > send_number';
$sum = $GLOBALS['db']->getOne($sql);
if (empty($sum))
{
$return_res = 1;
}
return $return_res;
}
/**
* 判斷訂單的發貨單是否全部發貨
* @param int $order_id 訂單 id
* @return int 1全部發貨0未全部發貨-1部分發貨-2完全沒發貨
*/
function get_all_delivery_finish($order_id)
{
$return_res = 0;
if (empty($order_id))
{
return $return_res;
}
/* 未全部分單 */
if (!get_order_finish($order_id))
{
return $return_res;
}
/* 已全部分單 */
else
{
// 是否全部發貨
$sql = "SELECT COUNT(delivery_id)
FROM " . $GLOBALS['ecs']->table('delivery_order') . "
WHERE order_id = '$order_id'
AND status = 2 ";
$sum = $GLOBALS['db']->getOne($sql);
// 全部發貨
if (empty($sum))
{
$return_res = 1;
}
// 未全部發貨
else
{
/* 訂單全部發貨中時:當前發貨單總數 */
$sql = "SELECT COUNT(delivery_id)
FROM " . $GLOBALS['ecs']->table('delivery_order') . "
WHERE order_id = '$order_id'
AND status <> 1 ";
$_sum = $GLOBALS['db']->getOne($sql);
if ($_sum == $sum)
{
$return_res = -2; // 完全沒發貨
}
else
{
$return_res = -1; // 部分發貨
}
}
}
return $return_res;
}
function trim_array_walk(&$array_value)
{
if (is_array($array_value))
{
array_walk($array_value, 'trim_array_walk');
}else{
$array_value = trim($array_value);
}
}
function intval_array_walk(&$array_value)
{
if (is_array($array_value))
{
array_walk($array_value, 'intval_array_walk');
}else{
$array_value = intval($array_value);
}
}
/**
* 刪除發貨單(不包括已退貨的單子)
* @param int $order_id 訂單 id
* @return int 1成功0失敗
*/
function del_order_delivery($order_id)
{
$return_res = 0;
if (empty($order_id))
{
return $return_res;
}
$sql = 'DELETE O, G
FROM ' . $GLOBALS['ecs']->table('delivery_order') . ' AS O, ' . $GLOBALS['ecs']->table('delivery_goods') . ' AS G
WHERE O.order_id = \'' . $order_id . '\'
AND O.status = 0
AND O.delivery_id = G.delivery_id';
$query = $GLOBALS['db']->query($sql, 'SILENT');
if ($query)
{
$return_res = 1;
}
return $return_res;
}
/**
* 刪除訂單所有相關單子
* @param int $order_id 訂單 id
* @param int $action_array 操作列表 Array('delivery', 'back', ......)
* @return int 1成功0失敗
*/
function del_delivery($order_id, $action_array)
{
$return_res = 0;
if (empty($order_id) || empty($action_array))
{
return $return_res;
}
$query_delivery = 1;
$query_back = 1;
if (in_array('delivery', $action_array))
{
$sql = 'DELETE O, G
FROM ' . $GLOBALS['ecs']->table('delivery_order') . ' AS O, ' . $GLOBALS['ecs']->table('delivery_goods') . ' AS G
WHERE O.order_id = \'' . $order_id . '\'
AND O.delivery_id = G.delivery_id';
$query_delivery = $GLOBALS['db']->query($sql, 'SILENT');
}
if (in_array('back', $action_array))
{
$sql = 'DELETE O, G
FROM ' . $GLOBALS['ecs']->table('back_order') . ' AS O, ' . $GLOBALS['ecs']->table('back_goods') . ' AS G
WHERE O.order_id = \'' . $order_id . '\'
AND O.back_id = G.back_id';
$query_back = $GLOBALS['db']->query($sql, 'SILENT');
}
if ($query_delivery && $query_back)
{
$return_res = 1;
}
return $return_res;
}
/**
* 獲取發貨單列表信息
*
* @access public
* @param
*
* @return void
*/
function delivery_list()
{
$result = get_filter();
if ($result === false)
{
$aiax = isset($_GET['is_ajax']) ? $_GET['is_ajax'] : 0;
/* 過濾信息 */
$filter['delivery_sn'] = empty($_REQUEST['delivery_sn']) ? '' : trim($_REQUEST['delivery_sn']);
$filter['order_sn'] = empty($_REQUEST['order_sn']) ? '' : trim($_REQUEST['order_sn']);
$filter['order_id'] = empty($_REQUEST['order_id']) ? 0 : intval($_REQUEST['order_id']);
if ($aiax == 1 && !empty($_REQUEST['consignee']))
{
$_REQUEST['consignee'] = json_str_iconv($_REQUEST['consignee']);
}
$filter['consignee'] = empty($_REQUEST['consignee']) ? '' : trim($_REQUEST['consignee']);
$filter['status'] = isset($_REQUEST['status']) ? $_REQUEST['status'] : -1;
$filter['sort_by'] = empty($_REQUEST['sort_by']) ? 'update_time' : trim($_REQUEST['sort_by']);
$filter['sort_order'] = empty($_REQUEST['sort_order']) ? 'DESC' : trim($_REQUEST['sort_order']);
$where = 'WHERE 1 ';
if ($filter['order_sn'])
{
$where .= " AND order_sn LIKE '%" . mysql_like_quote($filter['order_sn']) . "%'";
}
if ($filter['consignee'])
{
$where .= " AND consignee LIKE '%" . mysql_like_quote($filter['consignee']) . "%'";
}
if ($filter['status'] >= 0)
{
$where .= " AND status = '" . mysql_like_quote($filter['status']) . "'";
}
if ($filter['delivery_sn'])
{
$where .= " AND delivery_sn LIKE '%" . mysql_like_quote($filter['delivery_sn']) . "%'";
}
/* 獲取管理員信息 */
$admin_info = admin_info();
/* 如果管理員屬於某個辦事處,只列出這個辦事處管轄的發貨單 */
if ($admin_info['agency_id'] > 0)
{
$where .= " AND agency_id = '" . $admin_info['agency_id'] . "' ";
}
/* 如果管理員屬於某個供貨商,只列出這個供貨商的發貨單 */
if ($admin_info['suppliers_id'] > 0)
{
$where .= " AND suppliers_id = '" . $admin_info['suppliers_id'] . "' ";
}
/* 分頁大小 */
$filter['page'] = empty($_REQUEST['page']) || (intval($_REQUEST['page']) <= 0) ? 1 : intval($_REQUEST['page']);
if (isset($_REQUEST['page_size']) && intval($_REQUEST['page_size']) > 0)
{
$filter['page_size'] = intval($_REQUEST['page_size']);
}
elseif (isset($_COOKIE['ECSCP']['page_size']) && intval($_COOKIE['ECSCP']['page_size']) > 0)
{
$filter['page_size'] = intval($_COOKIE['ECSCP']['page_size']);
}
else
{
$filter['page_size'] = 15;
}
/* 記錄總數 */
$sql = "SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('delivery_order') . $where;
$filter['record_count'] = $GLOBALS['db']->getOne($sql);
$filter['page_count'] = $filter['record_count'] > 0 ? ceil($filter['record_count'] / $filter['page_size']) : 1;
/* 查詢 */
$sql = "SELECT delivery_id, delivery_sn, order_sn, order_id, add_time, action_user, consignee, country,
province, city, district, tel, status, update_time, email, suppliers_id
FROM " . $GLOBALS['ecs']->table("delivery_order") . "
$where
ORDER BY " . $filter['sort_by'] . " " . $filter['sort_order']. "
LIMIT " . ($filter['page'] - 1) * $filter['page_size'] . ", " . $filter['page_size'] . " ";
set_filter($filter, $sql);
}
else
{
$sql = $result['sql'];
$filter = $result['filter'];
}
/* 獲取供貨商列表 */
$suppliers_list = get_suppliers_list();
$_suppliers_list = array();
foreach ($suppliers_list as $value)
{
$_suppliers_list[$value['suppliers_id']] = $value['suppliers_name'];
}
$row = $GLOBALS['db']->getAll($sql);
/* 格式化數據 */
foreach ($row AS $key => $value)
{
$row[$key]['add_time'] = local_date($GLOBALS['_CFG']['time_format'], $value['add_time']);
$row[$key]['update_time'] = local_date($GLOBALS['_CFG']['time_format'], $value['update_time']);
if ($value['status'] == 1)
{
$row[$key]['status_name'] = $GLOBALS['_LANG']['delivery_status'][1];
}
elseif ($value['status'] == 2)
{
$row[$key]['status_name'] = $GLOBALS['_LANG']['delivery_status'][2];
}
else
{
$row[$key]['status_name'] = $GLOBALS['_LANG']['delivery_status'][0];
}
$row[$key]['suppliers_name'] = isset($_suppliers_list[$value['suppliers_id']]) ? $_suppliers_list[$value['suppliers_id']] : '';
}
$arr = array('delivery' => $row, 'filter' => $filter, 'page_count' => $filter['page_count'], 'record_count' => $filter['record_count']);
return $arr;
}
/**
* 獲取退貨單列表信息
*
* @access public
* @param
*
* @return void
*/
function back_list()
{
$result = get_filter();
if ($result === false)
{
$aiax = isset($_GET['is_ajax']) ? $_GET['is_ajax'] : 0;
/* 過濾信息 */
$filter['delivery_sn'] = empty($_REQUEST['delivery_sn']) ? '' : trim($_REQUEST['delivery_sn']);
$filter['order_sn'] = empty($_REQUEST['order_sn']) ? '' : trim($_REQUEST['order_sn']);
$filter['order_id'] = empty($_REQUEST['order_id']) ? 0 : intval($_REQUEST['order_id']);
if ($aiax == 1 && !empty($_REQUEST['consignee']))
{
$_REQUEST['consignee'] = json_str_iconv($_REQUEST['consignee']);
}
$filter['consignee'] = empty($_REQUEST['consignee']) ? '' : trim($_REQUEST['consignee']);
$filter['sort_by'] = empty($_REQUEST['sort_by']) ? 'update_time' : trim($_REQUEST['sort_by']);
$filter['sort_order'] = empty($_REQUEST['sort_order']) ? 'DESC' : trim($_REQUEST['sort_order']);
$where = 'WHERE 1 ';
if ($filter['order_sn'])
{
$where .= " AND order_sn LIKE '%" . mysql_like_quote($filter['order_sn']) . "%'";
}
if ($filter['consignee'])
{
$where .= " AND consignee LIKE '%" . mysql_like_quote($filter['consignee']) . "%'";
}
if ($filter['delivery_sn'])
{
$where .= " AND delivery_sn LIKE '%" . mysql_like_quote($filter['delivery_sn']) . "%'";
}
/* 獲取管理員信息 */
$admin_info = admin_info();
/* 如果管理員屬於某個辦事處,只列出這個辦事處管轄的發貨單 */
if ($admin_info['agency_id'] > 0)
{
$where .= " AND agency_id = '" . $admin_info['agency_id'] . "' ";
}
/* 如果管理員屬於某個供貨商,只列出這個供貨商的發貨單 */
if ($admin_info['suppliers_id'] > 0)
{
$where .= " AND suppliers_id = '" . $admin_info['suppliers_id'] . "' ";
}
/* 分頁大小 */
$filter['page'] = empty($_REQUEST['page']) || (intval($_REQUEST['page']) <= 0) ? 1 : intval($_REQUEST['page']);
if (isset($_REQUEST['page_size']) && intval($_REQUEST['page_size']) > 0)
{
$filter['page_size'] = intval($_REQUEST['page_size']);
}
elseif (isset($_COOKIE['ECSCP']['page_size']) && intval($_COOKIE['ECSCP']['page_size']) > 0)
{
$filter['page_size'] = intval($_COOKIE['ECSCP']['page_size']);
}
else
{
$filter['page_size'] = 15;
}
/* 記錄總數 */
$sql = "SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('back_order') . $where;
$filter['record_count'] = $GLOBALS['db']->getOne($sql);
$filter['page_count'] = $filter['record_count'] > 0 ? ceil($filter['record_count'] / $filter['page_size']) : 1;
/* 查詢 */
$sql = "SELECT back_id, delivery_sn, order_sn, order_id, add_time, action_user, consignee, country,
province, city, district, tel, status, update_time, email, return_time
FROM " . $GLOBALS['ecs']->table("back_order") . "
$where
ORDER BY " . $filter['sort_by'] . " " . $filter['sort_order']. "
LIMIT " . ($filter['page'] - 1) * $filter['page_size'] . ", " . $filter['page_size'] . " ";
set_filter($filter, $sql);
}
else
{
$sql = $result['sql'];
$filter = $result['filter'];
}
$row = $GLOBALS['db']->getAll($sql);
/* 格式化數據 */
foreach ($row AS $key => $value)
{
$row[$key]['return_time'] = local_date($GLOBALS['_CFG']['time_format'], $value['return_time']);
$row[$key]['add_time'] = local_date($GLOBALS['_CFG']['time_format'], $value['add_time']);
$row[$key]['update_time'] = local_date($GLOBALS['_CFG']['time_format'], $value['update_time']);
if ($value['status'] == 1)
{
$row[$key]['status_name'] = $GLOBALS['_LANG']['delivery_status'][1];
}
else
{
$row[$key]['status_name'] = $GLOBALS['_LANG']['delivery_status'][0];
}
}
$arr = array('back' => $row, 'filter' => $filter, 'page_count' => $filter['page_count'], 'record_count' => $filter['record_count']);
return $arr;
}
/**
* 取得發貨單信息
* @param int $delivery_order 發貨單id如果delivery_order > 0 就按id查否則按sn查
* @param string $delivery_sn 發貨單號
* @return array 發貨單信息金額都有相應格式化的字段前綴是formated_
*/
function delivery_order_info($delivery_id, $delivery_sn = '')
{
$return_order = array();
if (empty($delivery_id) || !is_numeric($delivery_id))
{
return $return_order;
}
$where = '';
/* 獲取管理員信息 */
$admin_info = admin_info();
/* 如果管理員屬於某個辦事處,只列出這個辦事處管轄的發貨單 */
if ($admin_info['agency_id'] > 0)
{
$where .= " AND agency_id = '" . $admin_info['agency_id'] . "' ";
}
/* 如果管理員屬於某個供貨商,只列出這個供貨商的發貨單 */
if ($admin_info['suppliers_id'] > 0)
{
$where .= " AND suppliers_id = '" . $admin_info['suppliers_id'] . "' ";
}
$sql = "SELECT * FROM " . $GLOBALS['ecs']->table('delivery_order');
if ($delivery_id > 0)
{
$sql .= " WHERE delivery_id = '$delivery_id'";
}
else
{
$sql .= " WHERE delivery_sn = '$delivery_sn'";
}
$sql .= $where;
$sql .= " LIMIT 0, 1";
$delivery = $GLOBALS['db']->getRow($sql);
if ($delivery)
{
/* 格式化金額字段 */
$delivery['formated_insure_fee'] = price_format($delivery['insure_fee'], false);
$delivery['formated_shipping_fee'] = price_format($delivery['shipping_fee'], false);
/* 格式化時間字段 */
$delivery['formated_add_time'] = local_date($GLOBALS['_CFG']['time_format'], $delivery['add_time']);
$delivery['formated_update_time'] = local_date($GLOBALS['_CFG']['time_format'], $delivery['update_time']);
$return_order = $delivery;
}
return $return_order;
}
/**
* 取得退貨單信息
* @param int $back_id 退貨單 id如果 back_id > 0 就按 id 查,否則按 sn 查)
* @return array 退貨單信息(金額都有相應格式化的字段,前綴是 formated_
*/
function back_order_info($back_id)
{
$return_order = array();
if (empty($back_id) || !is_numeric($back_id))
{
return $return_order;
}
$where = '';
/* 獲取管理員信息 */
$admin_info = admin_info();
/* 如果管理員屬於某個辦事處,只列出這個辦事處管轄的發貨單 */
if ($admin_info['agency_id'] > 0)
{
$where .= " AND agency_id = '" . $admin_info['agency_id'] . "' ";
}
/* 如果管理員屬於某個供貨商,只列出這個供貨商的發貨單 */
if ($admin_info['suppliers_id'] > 0)
{
$where .= " AND suppliers_id = '" . $admin_info['suppliers_id'] . "' ";
}
$sql = "SELECT * FROM " . $GLOBALS['ecs']->table('back_order') . "
WHERE back_id = '$back_id'
$where
LIMIT 0, 1";
$back = $GLOBALS['db']->getRow($sql);
if ($back)
{
/* 格式化金額字段 */
$back['formated_insure_fee'] = price_format($back['insure_fee'], false);
$back['formated_shipping_fee'] = price_format($back['shipping_fee'], false);
/* 格式化時間字段 */
$back['formated_add_time'] = local_date($GLOBALS['_CFG']['time_format'], $back['add_time']);
$back['formated_update_time'] = local_date($GLOBALS['_CFG']['time_format'], $back['update_time']);
$back['formated_return_time'] = local_date($GLOBALS['_CFG']['time_format'], $back['return_time']);
$return_order = $back;
}
return $return_order;
}
/**
* 超級禮包發貨數處理
* @param array 超級禮包產品列表
* @param int 發貨數量
* @param int 訂單ID
* @param varchar 虛擬代碼
* @param int 禮包ID
* @return array 格式化結果
*/
function package_goods(&$package_goods, $goods_number, $order_id, $extension_code, $package_id)
{
$return_array = array();
if (count($package_goods) == 0 || !is_numeric($goods_number))
{
return $return_array;
}
foreach ($package_goods as $key=>$value)
{
$return_array[$key] = $value;
$return_array[$key]['order_send_number'] = $value['order_goods_number'] * $goods_number;
$return_array[$key]['sended'] = package_sended($package_id, $value['goods_id'], $order_id, $extension_code, $value['product_id']);
$return_array[$key]['send'] = ($value['order_goods_number'] * $goods_number) - $return_array[$key]['sended'];
$return_array[$key]['storage'] = $value['goods_number'];
if ($return_array[$key]['send'] <= 0)
{
$return_array[$key]['send'] = $GLOBALS['_LANG']['act_good_delivery'];
$return_array[$key]['readonly'] = 'readonly="readonly"';
}
/* 是否缺貨 */
if ($return_array[$key]['storage'] <= 0 && $GLOBALS['_CFG']['use_storage'] == '1')
{
$return_array[$key]['send'] = $GLOBALS['_LANG']['act_good_vacancy'];
$return_array[$key]['readonly'] = 'readonly="readonly"';
}
}
return $return_array;
}
/**
* 獲取超級禮包產品已發貨數
*
* @param int $package_id 禮包ID
* @param int $goods_id 禮包的產品ID
* @param int $order_id 訂單ID
* @param varchar $extension_code 虛擬代碼
* @param int $product_id 貨品id
*
* @return int 數值
*/
function package_sended($package_id, $goods_id, $order_id, $extension_code, $product_id = 0)
{
if (empty($package_id) || empty($goods_id) || empty($order_id) || empty($extension_code))
{
return false;
}
$sql = "SELECT SUM(DG.send_number)
FROM " . $GLOBALS['ecs']->table('delivery_goods') . " AS DG, " . $GLOBALS['ecs']->table('delivery_order') . " AS o
WHERE o.delivery_id = DG.delivery_id
AND o.status IN (0, 2)
AND o.order_id = '$order_id'
AND DG.parent_id = '$package_id'
AND DG.goods_id = '$goods_id'
AND DG.extension_code = '$extension_code'";
$sql .= ($product_id > 0) ? " AND DG.product_id = '$product_id'" : '';
$send = $GLOBALS['db']->getOne($sql);
return empty($send) ? 0 : $send;
}
/**
* 改變訂單中產品庫存
* @param int $order_id 訂單 id
* @param array $_sended Array(產品id => ‘此單發貨數量’)
* @param array $goods_list
* @return Bool
*/
function change_order_goods_storage_split($order_id, $_sended, $goods_list = array())
{
/* 參數檢查 */
if (!is_array($_sended) || empty($order_id))
{
return false;
}
foreach ($_sended as $key => $value)
{
// 產品(超值禮包)
if (is_array($value))
{
if (!is_array($goods_list))
{
$goods_list = array();
}
foreach ($goods_list as $goods)
{
if (($key != $goods['rec_id']) || (!isset($goods['package_goods_list']) || !is_array($goods['package_goods_list'])))
{
continue;
}
// 超值禮包無庫存,只減超值禮包產品庫存
foreach ($goods['package_goods_list'] as $package_goods)
{
if (!isset($value[$package_goods['goods_id']]))
{
continue;
}
// 減庫存:產品(超值禮包)(實貨)、產品(超值禮包)(虛貨)
$sql = "UPDATE " . $GLOBALS['ecs']->table('goods') ."
SET goods_number = goods_number - '" . $value[$package_goods['goods_id']] . "'
WHERE goods_id = '" . $package_goods['goods_id'] . "' ";
$GLOBALS['db']->query($sql);
}
}
}
// 產品(實貨)
elseif (!is_array($value))
{
/* 檢查是否為產品(實貨) */
foreach ($goods_list as $goods)
{
if ($goods['rec_id'] == $key && $goods['is_real'] == 1)
{
$sql = "UPDATE " . $GLOBALS['ecs']->table('goods') . "
SET goods_number = goods_number - '" . $value . "'
WHERE goods_id = '" . $goods['goods_id'] . "' ";
$GLOBALS['db']->query($sql, 'SILENT');
break;
}
}
}
}
return true;
}
/**
* 超值禮包虛擬卡發貨、跳過修改訂單產品發貨數的虛擬卡發貨
*
* @access public
* @param array $goods 超值禮包虛擬產品列表數組
* @param string $order_sn 本次操作的訂單
*
* @return boolen
*/
function package_virtual_card_shipping($goods, $order_sn)
{
if (!is_array($goods))
{
return false;
}
/* 包含加密解密函數所在文件 */
include_once(ROOT_PATH . 'includes/lib_code.php');
// 取出超值禮包中的虛擬產品信息
foreach ($goods as $virtual_goods_key => $virtual_goods_value)
{
/* 取出卡片信息 */
$sql = "SELECT card_id, card_sn, card_password, end_date, crc32
FROM ".$GLOBALS['ecs']->table('virtual_card')."
WHERE goods_id = '" . $virtual_goods_value['goods_id'] . "'
AND is_saled = 0
LIMIT " . $virtual_goods_value['num'];
$arr = $GLOBALS['db']->getAll($sql);
/* 判斷是否有庫存 沒有則推出循環 */
if (count($arr) == 0)
{
continue;
}
$card_ids = array();
$cards = array();
foreach ($arr as $virtual_card)
{
$card_info = array();
/* 卡號和密碼解密 */
if ($virtual_card['crc32'] == 0 || $virtual_card['crc32'] == crc32(AUTH_KEY))
{
$card_info['card_sn'] = decrypt($virtual_card['card_sn']);
$card_info['card_password'] = decrypt($virtual_card['card_password']);
}
elseif ($virtual_card['crc32'] == crc32(OLD_AUTH_KEY))
{
$card_info['card_sn'] = decrypt($virtual_card['card_sn'], OLD_AUTH_KEY);
$card_info['card_password'] = decrypt($virtual_card['card_password'], OLD_AUTH_KEY);
}
else
{
return false;
}
$card_info['end_date'] = date($GLOBALS['_CFG']['date_format'], $virtual_card['end_date']);
$card_ids[] = $virtual_card['card_id'];
$cards[] = $card_info;
}
/* 標記已經取出的卡片 */
$sql = "UPDATE ".$GLOBALS['ecs']->table('virtual_card')." SET ".
"is_saled = 1 ,".
"order_sn = '$order_sn' ".
"WHERE " . db_create_in($card_ids, 'card_id');
if (!$GLOBALS['db']->query($sql))
{
return false;
}
/* 獲取訂單信息 */
$sql = "SELECT order_id, order_sn, consignee, email FROM ".$GLOBALS['ecs']->table('order_info'). " WHERE order_sn = '$order_sn'";
$order = $GLOBALS['db']->GetRow($sql);
$cfg = $GLOBALS['_CFG']['send_ship_email'];
if ($cfg == '1')
{
/* 發送郵件 */
$GLOBALS['smarty']->assign('virtual_card', $cards);
$GLOBALS['smarty']->assign('order', $order);
$GLOBALS['smarty']->assign('goods', $virtual_goods_value);
$GLOBALS['smarty']->assign('send_time', date('Y-m-d H:i:s'));
$GLOBALS['smarty']->assign('shop_name', $GLOBALS['_CFG']['shop_name']);
$GLOBALS['smarty']->assign('send_date', date('Y-m-d'));
$GLOBALS['smarty']->assign('sent_date', date('Y-m-d'));
$tpl = get_mail_template('virtual_card');
$content = $GLOBALS['smarty']->fetch('str:' . $tpl['template_content']);
send_mail($order['consignee'], $order['email'], $tpl['template_subject'], $content, $tpl['is_html']);
}
}
return true;
}
/**
* 刪除發貨單時進行退貨
*
* @access public
* @param int $delivery_id 發貨單id
* @param array $delivery_order 發貨單信息數組
*
* @return void
*/
function delivery_return_goods($delivery_id, $delivery_order)
{
/* 查詢:取得發貨單產品 */
$goods_sql = "SELECT *
FROM " . $GLOBALS['ecs']->table('delivery_goods') . "
WHERE delivery_id = " . $delivery_order['delivery_id'];
$goods_list = $GLOBALS['db']->getAll($goods_sql);
/* 更新: */
foreach ($goods_list as $key=>$val)
{
$sql = "UPDATE " . $GLOBALS['ecs']->table('order_goods') .
" SET send_number = send_number-'".$goods_list[$key]['send_number']. "'".
" WHERE order_id = '".$delivery_order['order_id']."' AND goods_id = '".$goods_list[$key]['goods_id']."' LIMIT 1";
$GLOBALS['db']->query($sql);
}
$sql = "UPDATE " . $GLOBALS['ecs']->table('order_info') .
" SET shipping_status = '0' , order_status = 1".
" WHERE order_id = '".$delivery_order['order_id']."' LIMIT 1";
$GLOBALS['db']->query($sql);
}
/**
* 刪除發貨單時刪除其在訂單中的發貨單號
*
* @access public
* @param int $order_id 定單id
* @param string $delivery_invoice_no 發貨單號
*
* @return void
*/
function del_order_invoice_no($order_id, $delivery_invoice_no)
{
/* 查詢:取得訂單中的發貨單號 */
$sql = "SELECT invoice_no
FROM " . $GLOBALS['ecs']->table('order_info') . "
WHERE order_id = '$order_id'";
$order_invoice_no = $GLOBALS['db']->getOne($sql);
/* 如果為空就結束處理 */
if (empty($order_invoice_no))
{
return;
}
/* 去除當前發貨單號 */
$order_array = explode('<br>', $order_invoice_no);
$delivery_array = explode('<br>', $delivery_invoice_no);
foreach ($order_array as $key => $invoice_no)
{
if ($ii = array_search($invoice_no, $delivery_array))
{
unset($order_array[$key], $delivery_array[$ii]);
}
}
$arr['invoice_no'] = implode('<br>', $order_array);
update_order($order_id, $arr);
}
/**
* 獲取站點根目錄網址
*
* @access private
* @return Bool
*/
function get_site_root_url()
{
return 'http://' . $_SERVER['HTTP_HOST'] . str_replace('/' . ADMIN_PATH . '/order.php', '', PHP_SELF);
}
?>