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.
 
 
 
 

7837 lines
306 KiB

<?php
/**
* ECSHOP 订单管理
* ============================================================================
* 版权所有 2005-2016 上海商创网络科技有限公司,并保留所有权利。
* 网站地址: http://www.ecmoban.com;
* ----------------------------------------------------------------------------
* 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和
* 使用;不允许对程序代码以任何形式任何目的的再发布。
* ============================================================================
* $Author: yehuaixiao $
* $Id: order.php 17219 2011-01-27 10:49:19Z yehuaixiao $
*/
define('IN_ECS', true);
require(dirname(__FILE__) . '/includes/init.php');
require_once(ROOT_PATH . 'includes/lib_order.php');
require_once(ROOT_PATH . 'includes/lib_goods.php');
//商家单个权限 ecmoban模板堂 start
$order_back_apply = get_merchants_permissions($_SESSION['admin_id'], 'order_back_apply');
$smarty->assign('order_back_apply', $order_back_apply); //退换货权限
//商家单个权限 ecmoban模板堂 end
//ecmoban模板堂 --zhuo start
$adminru = get_admin_ru_id();
if($adminru['ru_id'] == 0){
$smarty->assign('priv_ru', 1);
}else{
$smarty->assign('priv_ru', 0);
}
//ecmoban模板堂 --zhuo end
/*------------------------------------------------------ */
//-- 订单查询
/*------------------------------------------------------ */
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'));
//ecmoban模板堂 --zhuo start
/* 获得该管理员的权限 */
$priv_str = $db->getOne("SELECT action_list FROM " .$ecs->table('admin_user'). " WHERE user_id = '" .$_SESSION['admin_id']. "'");
/* 如果被编辑的管理员拥有了all这个权限,将不能编辑 */
if ($priv_str == 'all')
{
$smarty->assign('priv_str', $priv_str);
}else{
$smarty->assign('priv_str', $priv_str);
}
//ecmoban模板堂 --zhuo end
$store_list = get_common_store_list();
$smarty->assign('store_list', $store_list);
/* 模板赋值 */
$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');
}
/*------------------------------------------------------ */
//-- 修改设置自动确认收货的时间(天为单位) ecmoban模板堂 --zhuo
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'edit_auto_delivery_time')
{
check_authz_json('order_edit');
$order_id = intval($_POST['id']);
$delivery_time = json_str_iconv(trim($_POST['val']));
/* 删除数据 */
$sql = "UPDATE " . $GLOBALS['ecs']->table('order_info') ." SET auto_delivery_time = '$delivery_time'". " WHERE order_id = '$order_id'";
$GLOBALS['db']->query($sql);
clear_cache_files();
make_json_result($delivery_time);
}
/*------------------------------------------------------ */
//-- 订单列表
/*------------------------------------------------------ */
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']));
//ecmoban模板堂 --zhuo start 订单导出
$smarty->assign('action_link3', array('href' => 'javascript:download_orderlist();', 'text' => $_LANG['11_order_export']));
//ecmoban模板堂 --zhuo end 订单导出
$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);
$store_list = get_common_store_list();
$smarty->assign('store_list', $store_list);
$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">');
//ecmoban模板堂 --zhuo start
/* 获得该管理员的权限 */
$priv_str = $db->getOne("SELECT action_list FROM " .$ecs->table('admin_user'). " WHERE user_id = '" .$_SESSION['admin_id']. "'");
/* 如果被编辑的管理员拥有了all这个权限,将不能编辑 */
if ($priv_str == 'all')
{
$smarty->assign('priv_str', $priv_str);
}else{
$smarty->assign('priv_str', $priv_str);
}
//ecmoban模板堂 --zhuo end
/* 显示模板 */
assign_query_info();
$smarty->display('order_list.htm');
}
/**
* 退换货订单
* by Leah
*/ elseif ($_REQUEST['act'] == 'return_list') {
/* 检查权限 */
admin_priv('order_back_apply');
/* 模板赋值 */
$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('full_page', 1);
$order_list = return_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']);
$store_list = get_common_store_list();
$smarty->assign('store_list', $store_list);
assign_query_info();
$smarty->display('return_list.htm');
}
/**
* 退换货分页 by Leah
*/
elseif ($_REQUEST['act'] == 'return_list_query') {
/* 检查权限 */
admin_priv('order_view');
/* 模板赋值 */
$order_list = return_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']);
$store_list = get_common_store_list();
$smarty->assign('store_list', $store_list);
make_json_result($smarty->fetch('return_list.htm'), '', array('filter' => $order_list['filter'], 'page_count' => $order_list['page_count']));
}
//ecmoban模板堂 --zhuo start 订单导出
elseif($_REQUEST['act'] == 'order_export'){
//export_csv($_SESSION['orders']);
$filename = date('YmdHis') . ".csv";
header("Content-type:text/csv");
header("Content-Disposition:attachment;filename=" . $filename);
header('Cache-Control:must-revalidate,post-check=0,pre-check=0');
header('Expires:0');
header('Pragma:public');
$order_list = order_list();
echo download_orderlist($order_list['orders']);
exit;
}
//ecmoban模板堂 --zhuo end 订单导出
/*------------------------------------------------------ */
//-- 排序、分页、查询
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'query')
{
/* 检查权限 */
admin_priv('order_view');
$order_list = order_list();
//ecmoban模板堂 --zhuo start
/* 获得该管理员的权限 */
$priv_str = $db->getOne("SELECT action_list FROM " .$ecs->table('admin_user'). " WHERE user_id = '" .$_SESSION['admin_id']. "'");
/* 如果被编辑的管理员拥有了all这个权限,将不能编辑 */
if ($priv_str == 'all')
{
$smarty->assign('priv_str', $priv_str);
}else{
$smarty->assign('priv_str', $priv_str);
}
//ecmoban模板堂 --zhuo end
$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');
}
//ecmoban模板堂 --zhuo start
$noTime = gmtime();
$date = array('order_status', 'shipping_status', 'pay_status', 'shipping_time', 'auto_delivery_time');
$orderInfo = get_table_date('order_info', "order_id = '$order_id'", $date);
if($_CFG['open_delivery_time'] == 1){
if($orderInfo['order_status'] == 5 && $orderInfo['shipping_status'] == 1 && $orderInfo['pay_status'] == 2){ //发货状态
$delivery_time = $orderInfo['shipping_time'] + 24 * 3600 * $orderInfo['auto_delivery_time'];
if($noTime > $delivery_time){ //自动确认发货操作
$sql = "UPDATE " .$GLOBALS['ecs']->table('order_info'). " SET order_status = '" .OS_SPLITED. "', shipping_status = '" .SS_RECEIVED. "', pay_status = '" .PS_PAYED. "' WHERE order_id = '$order_id'";
$GLOBALS['db']->query($sql);
}
}
}
//ecmoban模板堂 --zhuo end
/* 如果订单不存在,退出 */
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 (!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'] = $db->getOne($sql);
/* 格式化金额 */
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['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);
/* 自提点信息 */
$sql = "SELECT shipping_code FROM ". $ecs->table('shipping') ." WHERE shipping_id = '$order[shipping_id]'";
if($db->getOne($sql) == 'cac'){
$sql = "SELECT * FROM ".$ecs->table('shipping_point')." WHERE id IN (SELECT point_id FROM ".$ecs->table('order_info')." WHERE order_id='{$order['order_id']}')";
$order['point']= $db->getRow($sql);
}
/* 取得订单商品总重量 */
$weight_price = order_weight_price($order['order_id']);
$order['total_weight'] = $weight_price['formated_weight'];
/* 参数赋值:订单 */
$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.*, c.measure_unit, g.goods_number AS storage, g.model_inventory, g.model_attr as model_attr, 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
LEFT JOIN " . $ecs->table('category') . " AS c
ON g.cat_id = c.cat_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']);
}
}
}
if($row['model_inventory'] == 1){
$row['storage'] = get_warehouse_area_goods($row['warehouse_id'], $row['goods_id'], 'warehouse_goods');
}elseif($row['model_inventory'] == 2){
$row['storage'] = get_warehouse_area_goods($row['area_id'], $row['goods_id'], 'warehouse_area_goods');
}
//ecmoban模板堂 --zhuo start 商品金额促销
$row['goods_amount'] = $row['goods_price'] * $row['goods_number'];
$goods_con = get_con_goods_amount($row['goods_amount'], $row['goods_id'], 0, 0, $row['parent_id']);
$goods_con['amount'] = explode(',', $goods_con['amount']);
$row['amount'] = min($goods_con['amount']);
$row['dis_amount'] = $row['goods_amount'] - $row['amount'];
$row['discount_amount'] = price_format($row['dis_amount'], false);
//ecmoban模板堂 --zhuo end 商品金额促销
//ecmoban模板堂 --zhuo start //库存查询
$products = get_warehouse_id_attr_number($row['goods_id'], $row['goods_attr_id'], $row['ru_id'], $row['warehouse_id'], $row['area_id'], $row['model_attr']);
$row['goods_storage'] = $products['product_number'];
if($row['model_attr'] == 1){
$table_products = "products_warehouse";
$type_files = " and warehouse_id = '" .$row['warehouse_id']. "'";
}elseif($row['model_attr'] == 2){
$table_products = "products_area";
$type_files = " and area_id = '" .$row['area_id']. "'";
}else{
$table_products = "products";
$type_files = "";
}
$sql = "SELECT * FROM " .$GLOBALS['ecs']->table($table_products). " WHERE goods_id = '" .$row['goods_id']. "'" .$type_files. " LIMIT 0, 1";
$prod = $GLOBALS['db']->getRow($sql);
if(empty($prod)){ //当商品没有属性库存时
$row['goods_storage'] = $row['storage'];
}
$row['goods_storage'] = !empty($row['goods_storage']) ? $row['goods_storage'] : 0;
$row['storage'] = $row['goods_storage'];
$row['product_sn'] = $products['product_sn'];
//ecmoban模板堂 --zhuo end //库存查询
$row['formated_subtotal'] = price_format($row['amount']);
$row['formated_goods_price'] = price_format($row['goods_price']);
$row['warehouse_name'] = $db->getOne("select region_name from " .$ecs->table('region_warehouse'). " where region_id = '" .$row['warehouse_id']. "'");
$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);
/**
* 取得用户收货时间 以快物流信息显示为准,目前先用用户收货时间为准,后期修改TODO by Leah S
*/
$sql = "SELECT log_time FROM " . $ecs->table('order_action') . " WHERE order_id = '$order[order_id]' ";
$res_time = local_date($_CFG['time_format'], $db->getOne($sql));
$smarty->assign('res_time', $res_time);
/**
* by Leah E
*/
/* 取得订单操作记录 */
$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 = 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']]; //网店-省份
$sql = "select og.ru_id from " .$GLOBALS['ecs']->table('order_info') ." as oi ". "," .$GLOBALS['ecs']->table('order_goods'). " as og " .
" where oi.order_id = og.order_id and oi.order_id = '" .$order['order_id']. "' group by oi.order_id";
$ru_id = $GLOBALS['db']->getOne($sql);
if($ru_id > 0){
$sql = "select shoprz_brandName, shopNameSuffix from " .$GLOBALS['ecs']->table('merchants_shop_information') . " where user_id = '$ru_id'";
$shop_info = $GLOBALS['db']->getRow($sql);
$lable_box['t_shop_name'] = $shop_info['shoprz_brandName'] . $shop_info['shopNameSuffix']; //店铺-名称
}else{
$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']));
//查询订单是否有商品退款
$sql = "SELECT count(*) FROM " .$GLOBALS['ecs']->table('order_return'). " WHERE order_id = '$order_id'";
$GLOBALS['db']->getOne($sql);
/* 显示模板 */
assign_query_info();
$smarty->display('order_info.htm');
}
}
/* ------------------------------------------------------ */
//-- 退货单详情
/* ------------------------------------------------------ */
/**
* by Leah
*/ elseif ($_REQUEST['act'] == 'return_info') {
/* 检查权限 */
admin_priv('order_back_apply');
$ret_id = intval(trim($_REQUEST['ret_id']));
$rec_id = intval(trim($_REQUEST['rec_id']));
/* 根据发货单id查询发货单信息 */
if (!empty($ret_id) || !empty($rec_id)) {
$back_order = return_order_info($ret_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_return') . " 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);
/* 是否保价 */
$back_order['insure_yn'] = empty($order['insure_fee']) ? 0 : 1;
/* 取得发货单商品 */;
$goods_list = get_return_order_goods($rec_id);
/**
* 取的退换货订单商品
*/
$return_list = get_return_goods($ret_id);
//快递公司
/* 取得可用的配送方式列表 */
$region_id_list = array(
$back_order['country'], $back_order['province'], $back_order['city'], $back_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']); //计算运费
$free_price = free_price($shipping['configure']); //免费额度
$shipping_list[$key]['shipping_fee'] = $shipping_fee;
$shipping_list[$key]['format_shipping_fee'] = price_format($shipping_fee);
$shipping_list[$key]['free_money'] = price_format($free_price['configure']['free_money']);
}
$smarty->assign('shipping_list', $shipping_list);
/* 取得退货订单操作记录 */
$action_list = get_return_action($ret_id);
$smarty->assign('action_list', $action_list);
/* 模板赋值 */
$smarty->assign('back_order', $back_order);
$smarty->assign('exist_real_goods', $exist_real_goods);
$smarty->assign('goods_list', $goods_list);
$smarty->assign('return_list', $return_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('return_order_info.htm');
exit; //
}
/*------------------------------------------------------ */
//-- 发货单列表
/*------------------------------------------------------ */
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);
/* 检查此单发货商品库存缺货情况 ecmoban模板堂 --zhuo start 下单减库存*/
$delivery_stock_sql = "SELECT G.model_attr, G.model_inventory, DG.goods_id, DG.delivery_id, DG.is_real, DG.send_number AS sums, G.goods_number AS storage, G.goods_name, DG.send_number," .
" OG.goods_attr_id, OG.warehouse_id, OG.area_id, OG.ru_id, OG.order_id, OG.product_id FROM " . $GLOBALS['ecs']->table('delivery_goods') . " AS DG, " .
$GLOBALS['ecs']->table('goods') . " AS G, " .
$GLOBALS['ecs']->table('delivery_order') . " AS D, " .
$GLOBALS['ecs']->table('order_goods') . " AS OG " .
" WHERE DG.goods_id = G.goods_id AND DG.delivery_id = D.delivery_id AND D.order_id = OG.order_id AND DG.delivery_id = '$delivery_id' GROUP BY OG.rec_id ";
$delivery_stock_result = $GLOBALS['db']->getAll($delivery_stock_sql);
for($i=0; $i<count($delivery_stock_result); $i++){
if($delivery_stock_result[$i]['model_attr'] == 1){
$table_products = "products_warehouse";
$type_files = " and warehouse_id = '" .$delivery_stock_result[$i]['warehouse_id']. "'";
}elseif($delivery_stock_result[$i]['model_attr'] == 2){
$table_products = "products_area";
$type_files = " and area_id = '" .$delivery_stock_result[$i]['area_id']. "'";
}else{
$table_products = "products";
$type_files = "";
}
$sql = "SELECT * FROM " .$GLOBALS['ecs']->table($table_products). " WHERE goods_id = '" .$delivery_stock_result[$i]['goods_id']. "'" .$type_files. " LIMIT 0, 1";
$prod = $GLOBALS['db']->getRow($sql);
/* 如果商品存在规格就查询规格,如果不存在规格按商品库存查询 */
if(empty($prod)){
if($delivery_stock_result[$i]['model_inventory'] == 1){
$delivery_stock_result[$i]['storage'] = get_warehouse_area_goods($delivery_stock_result[$i]['warehouse_id'], $delivery_stock_result[$i]['goods_id'], 'warehouse_goods');
}elseif($delivery_stock_result[$i]['model_inventory'] == 2){
$delivery_stock_result[$i]['storage'] = get_warehouse_area_goods($delivery_stock_result[$i]['area_id'], $delivery_stock_result[$i]['goods_id'], 'warehouse_area_goods');
}
}else{
$products = get_warehouse_id_attr_number($delivery_stock_result[$i]['goods_id'], $delivery_stock_result[$i]['goods_attr_id'], $delivery_stock_result[$i]['ru_id'], $delivery_stock_result[$i]['warehouse_id'], $delivery_stock_result[$i]['area_id'], $delivery_stock_result[$i]['model_attr']);
$delivery_stock_result[$i]['storage'] = $products['product_number'];
}
if (($delivery_stock_result[$i]['sums'] > $delivery_stock_result[$i]['storage'] || $delivery_stock_result[$i]['storage'] <= 0) && (($_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_SHIP) || ($_CFG['use_storage'] == '0' && $delivery_stock_result[$i]['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 ($delivery_stock_result[$i]['is_real'] == 0)
{
$virtual_goods[] = array(
'goods_id' => $delivery_stock_result[$i]['goods_id'],
'goods_name' => $delivery_stock_result[$i]['goods_name'],
'num' => $delivery_stock_result[$i]['send_number']
);
}
}
//ecmoban模板堂 --zhuo end 下单减库存
/* 发货 */
/* 处理虚拟卡 商品(虚货) */
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)
{
/* 商品(实货)、超级礼包(实货) ecmoban模板堂 --zhuo */
if ($value['is_real'] != 0)
{
//(货品)
if (!empty($value['product_id']))
{
if($value['model_attr'] == 1){
$minus_stock_sql = "UPDATE " . $GLOBALS['ecs']->table('products_warehouse') . "
SET product_number = product_number - " . $value['sums'] . "
WHERE product_id = " . $value['product_id'];
}elseif($value['model_attr'] == 2){
$minus_stock_sql = "UPDATE " . $GLOBALS['ecs']->table('products_area') . "
SET product_number = product_number - " . $value['sums'] . "
WHERE product_id = " . $value['product_id'];
}else{
$minus_stock_sql = "UPDATE " . $GLOBALS['ecs']->table('products') . "
SET product_number = product_number - " . $value['sums'] . "
WHERE product_id = " . $value['product_id'];
}
}else{
if($value['model_inventory'] == 1){
$minus_stock_sql = "UPDATE " . $GLOBALS['ecs']->table('warehouse_goods') . "
SET region_number = region_number - " . $value['sums'] . "
WHERE goods_id = " . $value['goods_id'] . " AND region_id = " . $value['warehouse_id'];
}elseif($value['model_inventory'] == 2){
$minus_stock_sql = "UPDATE " . $GLOBALS['ecs']->table('warehouse_area_goods') . "
SET region_number = region_number - " . $value['sums'] . "
WHERE goods_id = " . $value['goods_id'] . " AND region_id = " . $value['area_id'];
}else{
$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');
$logs_other = array(
'goods_id' =>$value['goods_id'],
'order_id' => $value['order_id'],
'use_storage' =>$_CFG['stock_dec_time'],
'admin_id' =>$_SESSION['admin_id'],
'number' => "- " . $value['sums'],
'model_inventory' =>$value['model_inventory'],
'model_attr' =>$value['model_attr'],
'product_id' =>$value['product_id'],
'warehouse_id' =>$value['warehouse_id'],
'area_id' =>$value['area_id'],
'add_time' => gmtime()
);
$GLOBALS['db']->autoExecute($GLOBALS['ecs']->table('goods_inventory_logs'), $logs_other, 'INSERT');
}
}
}
/* 修改发货单信息 */
$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('confirm_url', $ecs->url() . 'user.php?act=order_detail&order_id=' . $order['order_id']); //by wu
$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 ($GLOBALS['_CFG']['sms_order_shipped'] == '1' && $order['mobile'] != '')
{
include_once('../includes/cls_sms.php');
$sms = new sms();
$sms->send($order['mobile'], sprintf($GLOBALS['_LANG']['order_shipped_sms'], $order['order_sn'],
local_date($GLOBALS['_LANG']['sms_time_format']), $GLOBALS['_CFG']['shop_name']), 0);
}
/* 更新商品销量 */
$sql = 'SELECT goods_id,goods_number FROM '.$GLOBALS['ecs']->table('order_goods').' WHERE order_id ='.$order_id;
$order_res = $GLOBALS['db']->getAll($sql);
foreach($order_res as $idx=>$val)
{
$sql = 'SELECT SUM(og.goods_number) as goods_number ' .
'FROM ' . $GLOBALS['ecs']->table('goods') . ' AS g, ' .
$GLOBALS['ecs']->table('order_info') . ' AS o, ' .
$GLOBALS['ecs']->table('order_goods') . ' AS og ' .
"WHERE g.is_on_sale = 1 AND g.is_alone_sale = 1 AND g.is_delete = 0 AND og.order_id = o.order_id AND og.goods_id = g.goods_id " .
"AND (o.order_status = '" . OS_CONFIRMED . "' OR o.order_status = '" . OS_SPLITED . "') " .
"AND (o.pay_status = '" . PS_PAYED . "' OR o.pay_status = '" . PS_PAYING . "') " .
"AND (o.shipping_status = '" . SS_SHIPPED . "' OR o.shipping_status = '" . SS_RECEIVED . "') AND g.goods_id=".$val['goods_id'];
$sales_volume = $GLOBALS['db']->getOne($sql);
$sql = "update " . $ecs->table('goods') . " set sales_volume='$sales_volume' WHERE goods_id =".$val['goods_id'];
$db->query($sql);
}
}
/* 清除缓存 */
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');
}
/**
* 退换货原因列表 by Leah
*/ elseif ($_REQUEST['act'] == 'back_cause_list') {
/* 检查权限 */
admin_priv('order_back_cause');
/* 查询 */
$result = cause_list(0, 0, FALSE);
/* 模板赋值 */
$smarty->assign('ur_here', $_LANG['10_back_order']);
$smarty->assign('action_link', array('href' => 'order.php?act=add_return_cause', 'text' => '添加退换货原因'));
$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('cause_list', $result);
$smarty->assign('sort_update_time', '<img src="images/sort_desc.gif">');
/* 显示模板 */
assign_query_info();
$smarty->display('back_cause_list.htm');
}
/**
* 添加退货原因
* by Leah
*/ elseif ($_REQUEST['act'] == 'add_return_cause') {
/* 检查权限 */
admin_priv('add_return_cause');
$cause_select = cause_list(0, 0, true);
$smarty->assign('cause_list', $cause_select);
$smarty->assign('form_act', 'inser_cause');
$smarty->display('back_cause_info.htm');
}
/**
* 添加退换货原因 by Leah
*
*/ elseif ($_REQUEST['act'] == 'inser_cause') {
$cause['cause_name'] = !empty($_REQUEST['cause_name']) ? $_REQUEST['cause_name'] : '';
$cause['parent_id'] = !empty($_REQUEST['parent_id']) ? intval($_REQUEST['parent_id']) : 0;
$cause['sort_order'] = !empty($_REQUEST['sort_order']) ? intval($_REQUEST['sort_order']) : 50;
$cause['is_show'] = !empty($_REQUEST['is_show']) ? intval($_REQUEST['is_show']) : 0;
if (cause_exists($cause['cause_name'], $cause['parent_id'])) {
/* 同级别下不能有重复的分类名称 */
$link[] = array('text' => $_LANG['go_back'], 'href' => 'javascript:history.back(-1)');
sys_msg('退换货不能有重复', 0, $link);
}
if ($db->autoExecute($ecs->table('return_cause'), $cause) !== false) {
/* 添加链接 */
$link[0]['text'] = '继续添加';
$link[0]['href'] = 'order.php?act=add_return_cause';
$link[1]['text'] = '返回列表页';
$link[1]['href'] = 'order.php?act=back_cause_list';
sys_msg($_LANG['catadd_succed'], 0, $link);
}
}
/**
* 编辑退换货原因
* by Leah
*/ elseif ($_REQUEST['act'] == 'edit_cause') {
/* 检查权限 */
admin_priv('add_return_cause');
$c_id = !empty($_REQUEST['c_id']) ? intval($_REQUEST['c_id']) : 0;
$cause_info = cause_info($c_id);
$cause_list = cause_list(0, $cause_info['parent_id'], true);
$smarty->assign('c_id', $c_id);
$smarty->assign('cause_info', $cause_info);
$smarty->assign('cause_list', $cause_list);
$smarty->assign('form_act', 'edit_cause_info');
$smarty->display('back_cause_info.htm');
}
/**
* 修改
* by leah
*/ elseif ($_REQUEST['act'] == 'edit_cause_info') {
$c_id = !empty($_REQUEST['c_id']) ? $_REQUEST['c_id'] : 0;
$cause['cause_name'] = !empty($_REQUEST['cause_name']) ? $_REQUEST['cause_name'] : '';
$cause['parent_id'] = !empty($_REQUEST['parent_id']) ? intval($_REQUEST['parent_id']) : 0;
$cause['sort_order'] = !empty($_REQUEST['sort_order']) ? intval($_REQUEST['sort_order']) : 50;
$cause['is_show'] = !empty($_REQUEST['is_show']) ? intval($_REQUEST['is_show']) : 0;
if (cause_exists($cause['cause_name'], $c_id)) {
/* 同级别下不能有重复的分类名称 */
$link[] = array('text' => $_LANG['go_back'], 'href' => 'javascript:history.back(-1)');
sys_msg('退换货不能有重复', 0, $link);
}
if ($db->autoExecute($ecs->table('return_cause'), $cause, 'UPDATE', "cause_id='$c_id'") !== false) {
/* 添加链接 */
$link[0]['text'] = '返回退换货原因列表';
$link[0]['href'] = 'order.php?act=back_cause_list';
sys_msg('修改成功', 0, $link);
}
}
/**
* 删除退换货原因
* by Leah
*/ elseif ($_REQUEST['act'] == 'remove_cause') {
$c_id = $_REQUEST['id'];
/* 删除退货单 */
$sql = "DELETE FROM " . $ecs->table('return_cause') . " WHERE cause_id = '$c_id'";
$db->query($sql);
$url = 'order.php?act=cause_query&' . str_replace('act=remove_cause', '', $_SERVER['QUERY_STRING']);
ecs_header("Location: $url\n");
exit;
}
/**
* 退换货 搜索、排序、分页 by Leah
*/ elseif ($_REQUEST['act'] == 'cause_query') {
$result = cause_list(0, 0, false);
$smarty->assign('cause_list', $result);
make_json_result($smarty->fetch('back_cause_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; //
}
/*------------------------------------------------------ */
//-- 修改退换金额 --zhuo
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'edit_refound_amount')
{
/* 检查权限 */
admin_priv('order_edit');
check_authz_json('order_edit');
$type = empty($_REQUEST['type']) ? 0 : intval($_REQUEST['type']);
$refound_amount = empty($_REQUEST['refound_amount']) ? 0 : floatval($_REQUEST['refound_amount']);
$order_id = empty($_REQUEST['order_id']) ? 0 : intval($_REQUEST['order_id']);
$rec_id = empty($_REQUEST['rec_id']) ? 0 : intval($_REQUEST['rec_id']);
$ret_d = empty($_REQUEST['ret_d']) ? 0 : intval($_REQUEST['ret_d']);
if($type == 1){
$sql = "SELECT should_return FROM " .$GLOBALS['ecs']->table('order_return'). " WHERE ret_id = '$ret_d'";
$should_return = $GLOBALS['db']->getOne($sql);
}else if($type == 2){
$sql = "SELECT shipping_fee FROM " .$GLOBALS['ecs']->table('order_info'). " WHERE order_id = '$order_id'";
$order_shipping_fee = $GLOBALS['db']->getOne($sql);
$sql = "SELECT SUM(return_shipping_fee) FROM " .$GLOBALS['ecs']->table('order_return'). " WHERE order_id = '$order_id'";
$return_shipping_fee = $GLOBALS['db']->getOne($sql);
$surplus_fee = $order_shipping_fee - $return_shipping_fee;
if($refound_amount > $surplus_fee){
$shipping_fee = $surplus_fee;
}else{
$shipping_fee = $refound_amount;
}
}
$data = array(
'should_return' => $should_return, //订单金额
'refound_amount' => $refound_amount, //退款订单金额
'order_shipping_fee' => $order_shipping_fee, //订单运费
'return_shipping_fee' => $return_shipping_fee, //已退运费
'surplus_fee' => $surplus_fee, //剩余可退运费
'shipping_fee' => $shipping_fee, //可退运费
'type' => $type
);
clear_cache_files();
make_json_result($data);
}
/*------------------------------------------------------ */
//-- 修改订单(处理提交)
/*------------------------------------------------------ */
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 warehouse_id, area_id FROM " .$GLOBALS['ecs']->table('order_goods'). " WHERE rec_id = '$rec_id' LIMIT 1";
$order_goods = $GLOBALS['db']->getRow($sql);
$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', " .
"warehouse_id = '" .$order_goods['warehouse_id']. "', " .
"area_id = '" .$order_goods['area_id']. "' " .
"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']);
$warehouse_id = intval($_POST['warehouse_id']);
$area_id = intval($_POST['area_id']);
$model_attr = intval($_POST['model_attr']);
$attr_price = $_POST['attr_price'];
$goods_price = $_POST['add_price'] != 'user_input' ? floatval($_POST['add_price']) : floatval($_POST['input_price']);
$goods_price = $goods_price + $attr_price;
$sql = "SELECT user_id FROM " .$GLOBALS['ecs']->table('goods'). " WHERE goods_id = '$goods_id' LIMIT 0, 1";
$goods_info = $GLOBALS['db']->getRow($sql);
$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]);
//ecmoban模板堂 --zhuo start
$attr_leftJoin = '';
$select = '';
if($model_attr == 1){
$select = " wap.attr_price as warehouse_attr_price, ";
$attr_leftJoin = 'LEFT JOIN ' . $GLOBALS['ecs']->table('warehouse_attr') . " AS wap ON g.goods_attr_id = wap.goods_attr_id AND wap.warehouse_id = '$warehouse_id' ";
}elseif($model_attr == 2){
$select = " waa.attr_price as area_attr_price, ";
$attr_leftJoin = 'LEFT JOIN ' . $GLOBALS['ecs']->table('warehouse_area_attr') . " AS waa ON g.goods_attr_id = waa.goods_attr_id AND area_id = '$area_id' ";
}
$sql = "SELECT g.attr_value, " .$select. " g.attr_price ".
'FROM ' . $GLOBALS['ecs']->table('goods_attr') ." AS g ".
"LEFT JOIN" . $ecs->table('attribute') . " AS a ON g.attr_id = a.attr_id " .
$attr_leftJoin .
"WHERE g.goods_attr_id in($attr_list)";
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
if($model_attr == 1){
$row['attr_price'] = $row['warehouse_attr_price'];
}elseif($model_attr == 2){
$row['attr_price'] = $row['area_attr_price'];
}else{
$row['attr_price'] = $row['attr_price'];
}
$attr_price = '';
if($row['attr_price'] > 0){
$attr_price = ":[" . price_format($row['attr_price']) . "]";
}
$attr_value[] = $row['attr_value'] . $attr_price;
}
//ecmoban模板堂 --zhuo end
if($attr_value){
$attr_value = implode(",",$attr_value);
}else{
$attr_value = "";
}
//ecmoban模板堂 --zhuo start
if($model_attr == 1){
$table_products = "products_warehouse";
$type_files = " and warehouse_id = '$warehouse_id'";
}elseif($model_attr == 2){
$table_products = "products_area";
$type_files = " and area_id = '$area_id'";
}else{
$table_products = "products";
$type_files = "";
}
$sql = "SELECT * FROM " .$GLOBALS['ecs']->table($table_products). " WHERE goods_id = '$goods_id'" .$type_files. " LIMIT 0, 1";
$prod = $GLOBALS['db']->getRow($sql);
//ecmoban模板堂 --zhuo end
if (is_spec($goods_attr) && !empty($prod))
{
$product_info = get_products_info($goods_id, $goods_attr, $warehouse_id, $area_id); //ecmoban模板堂 --zhuo
}
//商品存在规格 是货品 检查该货品库存
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, model_attr, warehouse_id, area_id, ru_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)."', '$model_attr', '$warehouse_id', '$area_id', '" .$goods_info['user_id']. "' " .
"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, model_attr, warehouse_id, area_id, ru_id) " .
"SELECT '$order_id', goods_id, goods_name, goods_sn, " .
"'$goods_number', market_price, '$goods_price', '" . $attr_value. "', " .
"is_real, extension_code, 0, 0, '$model_attr', '$warehouse_id', '$area_id', '" .$goods_info['user_id']. "' " .
"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)
{
//ecmoban模板堂 --zhuo start
$model_inventory = get_table_date("goods", "goods_id = '$goods_id'", array('model_inventory'), 2);
//(货品)
if (!empty($product_info['product_id']))
{
if($model_attr == 1){
$sql = "UPDATE " . $GLOBALS['ecs']->table('products_warehouse') . "
SET product_number = product_number - " . $goods_number . "
WHERE product_id = " . $product_info['product_id'];
}elseif($model_attr == 2){
$sql = "UPDATE " . $GLOBALS['ecs']->table('products_area') . "
SET product_number = product_number - " . $goods_number . "
WHERE product_id = " . $product_info['product_id'];
}else{
$sql = "UPDATE " . $GLOBALS['ecs']->table('products') . "
SET product_number = product_number - " . $goods_number . "
WHERE product_id = " . $product_info['product_id'];
}
}else{
if($model_inventory == 1){
$sql = "UPDATE " . $GLOBALS['ecs']->table('warehouse_goods') . "
SET region_number = region_number - " . $goods_number . "
WHERE goods_id = '$goods_id' AND region_id = '$warehouse_id'";
}elseif($model_inventory == 2){
$sql = "UPDATE " . $GLOBALS['ecs']->table('warehouse_area_goods') . "
SET region_number = region_number - " . $goods_number . "
WHERE goods_id = '$goods_id' AND region_id = '$area_id'";
}else{
$sql = "UPDATE " . $GLOBALS['ecs']->table('goods') . "
SET goods_number = goods_number - " . $goods_number . "
WHERE goods_id = '$goods_id'";
}
}
//ecmoban模板堂 --zhuo end
$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;
}
}
}
/**
* 修改退换货订单 by Leah
*/ elseif ($_REQUEST['act'] == 'return_edit') {
include_once(ROOT_PATH . 'includes/lib_transaction.php');
/* 检查权限 */
admin_priv('order_edit');
$order_id = isset($_GET['order_id']) ? intval($_GET['order_id']) : 0;
$ret_id = isset($_GET['ret_id']) ? intval($_GET['ret_id']) : 0;
/* 取得参数 step */
$step_list = array('user', 'goods', 'consignee', 'back_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);
$return = get_return_detail($ret_id);
$smarty->assign('return', $return);
$smarty->assign('order', $order);
}
// 选择配送方式
if ('back_shipping' == $step) {
/* 取得可用的配送方式列表 */
$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']); //计算运费
$free_price = free_price($shipping['configure']); //免费额度
$shipping_list[$key]['shipping_fee'] = $shipping_fee;
$shipping_list[$key]['format_shipping_fee'] = price_format($shipping_fee);
$shipping_list[$key]['free_money'] = price_format($free_price['configure']['free_money']);
}
$smarty->assign('shipping_list', $shipping_list);
}
/* 显示模板 */
assign_query_info();
$smarty->display('order_step.htm');
}
/**
* 修改退换货订单快递信息
* by leah
*/ elseif ($_REQUEST['act'] == 'edit_shipping') {
$order_id = isset($_GET['order_id']) ? intval($_GET['order_id']) : 0;
$ret_id = isset($_GET['ret_id']) ? intval($_GET['ret_id']) : 0;
$rec_id = isset($_GET['rec_id']) ? intval($_GET['rec_id']) : 0;
$shipping_id = isset($_REQUEST['shipping']) ? intval($_REQUEST['shipping']) : 0;
$invoice_no = isset($_REQUEST['invoice_no']) ? $_REQUEST['invoice_no'] : '';
$db->query("UPDATE " . $ecs->table('order_return') . " SET out_shipping_name = '$shipping_id' , out_invoice_no ='$invoice_no'" .
"WHERE ret_id = '$ret_id'");
$links[] = array('text' => $_LANG['return_sn'] . $_LANG['detail'], 'href' => 'order.php?act=return_info&ret_id=' . $ret_id . 'rec_id=' . $rec_id);
sys_msg($_LANG['act_ok'], 0, $links);
}
/*------------------------------------------------------ */
//-- 修改订单(载入页面)
/*------------------------------------------------------ */
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);
$warehouse_list = get_warehouse_list_goods();
$smarty->assign('warehouse_list', $warehouse_list); //仓库列表
/* 取得参数 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_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);
}
// 选择支付方式
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'] == 'search_area'){
check_authz_json('order_view');
$warehouse_id = intval($_REQUEST['warehouse_id']);
$sql = "SELECT region_id, region_name FROM " .$GLOBALS['ecs']->table('region_warehouse'). " WHERE region_type = 1 AND parent_id = '$warehouse_id'";
$region_list = $GLOBALS['db']->getAll($sql);
$select = '<select name="area_id">';
$select .= '<option value="0">请选择</option>';
if($region_list){
foreach($region_list AS $key=>$row){
$select .= '<option value="' .$row['region_id']. '">' .$row['region_name']. '</option>';
}
}
$select .= '</select>';
$result = $select;
make_json_result($result);
}
/*------------------------------------------------------ */
//-- 处理
/*------------------------------------------------------ */
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');
/* 模板赋值 */
$smarty->assign('ur_here', $_LANG['04_merge_order']);
$smarty->assign('action_link', array('href' => 'order.php?act=list', 'text' => $_LANG['02_order_list']));
$store_list = get_common_store_list();
$smarty->assign('store_list', $store_list);
/* 显示模板 */
assign_query_info();
$smarty->display('merge_order.htm');
}
/*------------------------------------------------------ */
//-- 订单打印模板(载入页面)
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'templates')
{
/* 检查权限 */
admin_priv('order_print'); //ecmoban模板堂 --zhuo
/* 读入订单打印模板文件 */
$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 = '';
$rec_id = ''; //by leah
$ret_id = ''; //by Leah
/* 检查权限 */
admin_priv('order_os_edit');
/* 取得订单id(可能是多个,多个sn)和操作备注(可能没有) */
if(isset($_REQUEST['order_id']))
{
$order_id= $_REQUEST['order_id'];
$rec_id = $_REQUEST['rec_id']; //by Leah
$ret_id = $_REQUEST['ret_id']; //by Leah
}
$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';
}
/* 付款 */
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';
}
/**
* 同意申请
* by ecmoban模板堂 --zhuo
*/ elseif (isset($_POST['agree_apply'])) {
$require_note = false;
$action = $_LANG['op_confirm'];
$operation = 'agree_apply';
}
/* 退款
* by Leah
*/
elseif (isset($_POST['refound'])) {
$require_note = $_CFG['order_return_note'] == 1;
$order = order_info($order_id);
$refound_amount = empty($_REQUEST['refound_amount']) ? '' : $_REQUEST['refound_amount'];
// if ($order['money_paid'] > 0)
// {
$show_refund1 = true;
// }
$anonymous = $order['user_id'] == 0;
$action = $_LANG['op_return'];
$operation = 'refound';
$smarty->assign('refound_amount', $refound_amount);
}
/**
* 收到退换货商品
* by Leah
*/ elseif (isset($_POST['receive_goods'])) {
$require_note = false;
$action = $_LANG['op_confirm'];
$operation = 'receive_goods';
}
/**
* 换出商品 -- 快递信息
* by Leah
*/ elseif (isset($_POST['send_submit'])) {
$shipping_id = $_POST['shipping_name'];
$invoice_no = $_POST['invoice_no'];
$action_note = $_POST['action_note'];
$sql = "SELECT shipping_name FROM " . $ecs->table('shipping') . " WHERE shipping_id =" . $shipping_id;
$shipping_name = $db->getOne($sql);
$require_note = false;
$action = $_LANG['op_confirm'];
$operation = 'receive_goods';
$db->query("UPDATE " . $ecs->table('order_return') . " SET out_shipping_name = '$shipping_id' ,out_invoice_no ='$invoice_no'" .
"WHERE rec_id = '$rec_id'");
}
/**
* 商品分单寄出
* by Leah
*/ elseif (isset($_POST['swapped_out'])) {
$require_note = false;
$action = $_LANG['op_confirm'];
$operation = 'swapped_out';
}
/**
* 商品分单寄出 分单
* by Leah
*/ elseif (isset($_POST['swapped_out_single'])) {
$require_note = false;
$action = $_LANG['op_confirm'];
$operation = 'swapped_out_single';
}
/**
* 完成退换货
* by Leah
*/ elseif (isset($_POST['complete'])) {
$require_note = false;
$action = $_LANG['op_confirm'];
$operation = 'complete';
}
/* 指派 */
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.*, c.measure_unit, 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 " .
'LEFT JOIN ' . $GLOBALS['ecs']->table('category') . ' AS c ON g.cat_id = c.cat_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;
}
/* 直接处理还是跳到详细页面 ecmoban模板堂 --zhuo ($require_note && $action_note == '')*/
if ($require_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('show_refund1', isset($show_refund1)); // 是否显示退款 // by Leah
$smarty->assign('anonymous', isset($anonymous) ? $anonymous : true); // 是否匿名
$smarty->assign('order_id', $order_id); // 订单id
$smarty->assign('rec_id', $rec_id); // 订单商品id //by Leah
$smarty->assign('ret_id', $ret_id); // 订单商品id // by Leah
$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) {
// by Leah S
if ($_REQUEST['ret_id']) {
ecs_header("Location: order.php?act=operate_post&order_id=" . $order_id .
"&operation=" . $operation . "&action_note=" . urlencode($action_note) . "&rec_id=" . $rec_id . "&ret_id=" . $ret_id . "\n");
exit;
} else {
/* 一个订单 */
ecs_header("Location: order.php?act=operate_post&order_id=" . $order_id .
"&operation=" . $operation . "&action_note=" . urlencode($action_note) . "\n");
exit;
}
//by Leah E
} 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, 2, $_SESSION['admin_id']);
}
/* 发送邮件 */
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, 3, $_SESSION['admin_id']);
}
/* 发送邮件 */
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
$rec_id = empty($_REQUEST['rec_id']) ? 0 : $_REQUEST['rec_id']; //by Leah
$ret_id = empty($_REQUEST['ret_id']) ? 0 : $_REQUEST['ret_id']; //by Leah
$return = ''; //by leah
//by Leah S
if ($ret_id) {
$return = 1;
}
//by Leah E
$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, 4, $_SESSION['admin_id']);
}
/* 发送邮件 */
$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_time'] = gmtime();
//预售定金处理
if($order['extension_code'] == 'presale' && $order['pay_status'] == 0){
$arr['pay_status'] = PS_PAYED_PART;
$arr['money_paid'] = $order['money_paid'] + $order['order_amount'];
$arr['order_amount']= $order['goods_amount'] + $order['shipping_fee'] + $order['insure_fee'] + $order['pay_fee'] + $order['tax'] + $order['pack_fee'] + $order['card_fee'] -
$order['surplus'] - $order['money_paid'] - $order['integral_money'] - $order['bonus'] - $order['order_amount'] - $order['discount'] ;
}else{
$arr['pay_status'] = PS_PAYED;
$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);
/* 更新商品销量 ecmoban模板堂 --zhuo */
$sql = 'SELECT goods_id,goods_number FROM '.$GLOBALS['ecs']->table('order_goods').' WHERE order_id ='.$order_id;
$order_res = $GLOBALS['db']->getAll($sql);
foreach($order_res as $idx=>$val)
{
$sql = 'SELECT SUM(og.goods_number) as goods_number ' .
'FROM ' . $GLOBALS['ecs']->table('goods') . ' AS g, ' .
$GLOBALS['ecs']->table('order_info') . ' AS o, ' .
$GLOBALS['ecs']->table('order_goods') . ' AS og ' .
"WHERE g.is_on_sale = 1 AND g.is_alone_sale = 1 AND g.is_delete = 0 AND og.order_id = o.order_id AND og.goods_id = g.goods_id " .
"AND (o.order_status = '" . OS_CONFIRMED . "' OR o.order_status = '" . OS_SPLITED . "') " .
"AND (o.pay_status = '" . PS_PAYED . "') " .
"AND (o.shipping_status = '" . SS_RECEIVED . "') AND g.goods_id=".$val['goods_id'];
$sales_volume = $GLOBALS['db']->getOne($sql);
$sql = "update " . $ecs->table('goods') . " set sales_volume='$sales_volume' WHERE goods_id =".$val['goods_id'];
$db->query($sql);
}
/* 记录log */
if($order['extension_code'] == 'presale' && $order['pay_status'] == 0){
order_action($order['order_sn'], OS_CONFIRMED, $order['shipping_status'], PS_PAYED_PART, $action_note);
/* 更新 pay_log */
update_pay_log($order_id);
}else{
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();
}
/* 分单确认 */
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']);
/* 订单是否已全部分单检查 */
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']);
$num = $value['storage']; //ecmoban模板堂 --zhuo
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, 5, $_SESSION['admin_id']);
}
/* 删除发货单 */
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);
/* 更新商品销量 ecmoban模板堂 --zhuo */
$sql = 'SELECT goods_id,goods_number FROM '.$GLOBALS['ecs']->table('order_goods').' WHERE order_id ='.$order_id;
$order_res = $GLOBALS['db']->getAll($sql);
foreach($order_res as $idx=>$val)
{
$sql = 'SELECT SUM(og.goods_number) as goods_number ' .
'FROM ' . $GLOBALS['ecs']->table('goods') . ' AS g, ' .
$GLOBALS['ecs']->table('order_info') . ' AS o, ' .
$GLOBALS['ecs']->table('order_goods') . ' AS og ' .
"WHERE g.is_on_sale = 1 AND g.is_alone_sale = 1 AND g.is_delete = 0 AND og.order_id = o.order_id AND og.goods_id = g.goods_id " .
"AND (o.order_status = '" . OS_CONFIRMED . "' OR o.order_status = '" . OS_SPLITED . "') " .
"AND (o.pay_status = '" . PS_PAYED . "') " .
"AND (o.shipping_status = '" . SS_RECEIVED . "') AND g.goods_id=".$val['goods_id'];
$sales_volume = $GLOBALS['db']->getOne($sql);
$sql = "update " . $ecs->table('goods') . " set sales_volume='$sales_volume' WHERE goods_id =".$val['goods_id'];
$db->query($sql);
}
/* 记录log */
order_action($order['order_sn'], $order['order_status'], SS_RECEIVED, $order['pay_status'], $action_note);
}
/*
* 收到退换货商品
* by ecmoban模板堂 --zhuo
*/
elseif ('agree_apply' == $operation) {
$arr = array('agree_apply' => 1); //收到用户退回商品
$GLOBALS['db']->autoExecute($GLOBALS['ecs']->table('order_return'), $arr, 'UPDATE', "rec_id = '$rec_id'");
/* 记录log TODO_LOG */
return_action($ret_id, RF_AGREE_APPLY, '', $action_note);
}
/*
* 收到退换货商品
* by Leah
*/
elseif ('receive_goods' == $operation) {
$arr = array('return_status' => 1); //收到用户退回商品
$GLOBALS['db']->autoExecute($GLOBALS['ecs']->table('order_return'), $arr, 'UPDATE', "rec_id = '$rec_id'");
$arr['pay_status'] = PS_PAYED;
$order['pay_status'] = PS_PAYED;
/* 记录log TODO_LOG */
return_action($ret_id, RF_RECEIVE, '', $action_note);
}
/**
* 换出商品寄出 ---- 分单
* by Leah
*/ elseif ('swapped_out_single' == $operation) {
$arr = array('return_status' => 2); //换出商品寄出
$GLOBALS['db']->autoExecute($GLOBALS['ecs']->table('order_return'), $arr, 'UPDATE', "rec_id = '$rec_id'");
return_action($ret_id, RF_SWAPPED_OUT_SINGLE, '', $action_note);
}
/**
* 换出商品寄出
* by leah
*/ elseif ('swapped_out' == $operation) {
$arr = array('return_status' => 3); //换出商品寄出
$GLOBALS['db']->autoExecute($GLOBALS['ecs']->table('order_return'), $arr, 'UPDATE', "rec_id = '$rec_id'");
return_action($ret_id, RF_SWAPPED_OUT, '', $action_note);
}
/**
* 完成退换货
* by Leah
*/ elseif ('complete' == $operation) {
$arr = array('return_status' => 4); //完成退换货
$sql = "SELECT return_type FROM " .$ecs->table('order_return'). " WHERE rec_id = '$rec_id'";
$return_type = $db->getOne($sql);
if($return_type == 0){
$return_note = FF_MAINTENANCE;
}else if($return_type == 1){
$return_note = FF_REFOUND;
}else if($return_type == 2){
$return_note = FF_EXCHANGE;
}
$GLOBALS['db']->autoExecute($GLOBALS['ecs']->table('order_return'), $arr, 'UPDATE', "rec_id = '$rec_id'");
return_action($ret_id, RF_COMPLETE, $return_note, $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, 3, $_SESSION['admin_id']);
}
/* 退还用户余额、积分、红包 */
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, 2, $_SESSION['admin_id']);
}
/* 发送邮件 */
$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);
}
/**
* 退款
* by Leah
*/ elseif ('refound' == $operation) {
include_once(ROOT_PATH . 'includes/lib_transaction.php');
//TODO
/* 定义当前时间 */
define('GMTIME_UTC', gmtime()); // 获取 UTC 时间戳
//退还红包
$order_goods = get_order_goods($order); //订单商品
foreach ($order_goods['goods_list'] as $key => $value) {
$array_rec_id[] = $value['rec_id'];
}
$return_info = return_order_info_byId($order_id); //退换货订单
foreach ($return_info as $key => $value) {
$array_rec_id1[] = $value['rec_id'];
}
$order_info = get_order_detail($order_id);
if (!array_diff($array_rec_id, $array_rec_id1)) {
//整单退换货
$return_count = return_order_info_byId($order_id, 0);
if ($return_count == 1) {
//退还红包
$bonus = $order_info['bonus'];
$sql = "UPDATE " . $GLOBALS['ecs']->table('user_bonus') . " SET used_time = '' , order_id = '' WHERE order_id = " . $order_id;
$GLOBALS['db']->query($sql);
}
}
/* 过滤数据 */
$_REQUEST['refund'] = isset($_REQUEST['refund']) ? $_REQUEST['refund'] : ''; // 退款类型
$_REQUEST['refund_amount'] = isset($_REQUEST['refund_amount']) ? $_REQUEST['refund_amount'] :
$_REQUEST['action_note'] = isset($_REQUEST['action_note']) ? $_REQUEST['action_note'] : ''; //退款说明
$shippingFee = isset($_REQUEST['shipping']) ? $_REQUEST['shipping'] : ''; //退款运费金额
/* 标记订单为“退货”、“未付款”、“未发货” */
// $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) {
$return_goods = get_return_order_goods1($rec_id); //退换货商品
$return_info = return_order_info($ret_id); //退换货订单
$order_goods = get_order_goods($order); //订单商品
$refund_type = $_REQUEST['refund'];
$refund_amount = $_REQUEST['refound_amount'] + $_REQUEST['shipping'];
$refund_note = $_REQUEST['refund_note'];
//退款
if(!empty($_REQUEST['action_note'])){
order_refund1($order, $refund_type, $refund_amount, $refund_note);
//标记order_return 表
$return_status = array('refound_status' => 1, 'actual_return' => $refund_amount, 'return_shipping_fee'=>$shippingFee);
$GLOBALS['db']->autoExecute($GLOBALS['ecs']->table('order_return'), $return_status, 'UPDATE', "rec_id = '$rec_id'");
}
}
/* 退货用户余额、积分、红包 */
$goods_price = $return_goods['goods_price'] * $return_goods['send_number'];
return_surplus_integral_bonus($return_info['user_id'], $goods_price, $return_info['should_return1']);
/* 如果使用库存,则增加库存(不论何时减库存都需要) */
if ($_CFG['use_storage'] == '1') {
if ($_CFG['stock_dec_time'] == SDT_SHIP) {
change_order_goods_storage($order_id, false, SDT_SHIP, 6, $_SESSION['admin_id']);
} elseif ($_CFG['stock_dec_time'] == SDT_PLACE) {
change_order_goods_storage($order_id, false, SDT_PLACE, 6, $_SESSION['admin_id']);
}
}
/* 记录log */
return_action($ret_id, '', FF_REFOUND, $action_note);
}
/* 退货 by Leah */
elseif ('return' == $operation) {
//TODO
/* 定义当前时间 */
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, 6, $_SESSION['admin_id']);
} elseif ($_CFG['stock_dec_time'] == SDT_PLACE) {
change_order_goods_storage($order['order_id'], false, SDT_PLACE, 6, $_SESSION['admin_id']);
}
}
/* 退货用户余额、积分、红包 */
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');
}
/**
* by Leah s
*/
if ($return) {
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=return_info&ret_id=' . $ret_id . '&rec_id=' . $rec_id); //by Leah
sys_msg($_LANG['act_ok'] . $msg, 0, $links);
} else {
/* 操作成功 */
$links[] = array('text' => $_LANG['order_info'], 'href' => 'order.php?act=info&order_id=' . $order_id);
sys_msg($_LANG['act_ok'] . $msg, 0, $links);
}
/**
* by Leah e
*/
}
//ecmoban模板堂 --zhuo start
elseif ($_REQUEST['act'] == 'json')
{
include_once(ROOT_PATH . 'includes/cls_json.php');
$json = new JSON();
$goods_id = isset($_REQUEST['goods_id'])?intval($_REQUEST['goods_id']) : 0;
//ecmoban模板堂 --zhuo start
$warehouse_id = isset($_REQUEST['warehouse_id'])?intval($_REQUEST['warehouse_id']):0;
$area_id = isset($_REQUEST['area_id'])?intval($_REQUEST['area_id']):0;
$user_id = isset($_REQUEST['user_id'])?intval($_REQUEST['user_id']):0;
$model_attr = isset($_REQUEST['model_attr'])?intval($_REQUEST['model_attr']):0;
$goods_number = isset($_REQUEST['goods_number'])?intval($_REQUEST['goods_number']):0;
//ecmoban模板堂 --zhuo end
$func = $_REQUEST['func'];
if ($func == 'get_goods_info')
{
/* 取得商品信息 */
$leftJoin = " left join " .$GLOBALS['ecs']->table('warehouse_goods'). " as wg on g.goods_id = wg.goods_id and wg.region_id = '$warehouse_id' ";
$leftJoin .= " left join " .$GLOBALS['ecs']->table('warehouse_area_goods'). " as wag on g.goods_id = wag.goods_id and wag.region_id = '$area_id' ";
$sql = "SELECT g.goods_id, c.cat_name, g.goods_sn, g.goods_name, b.brand_name, g.market_price, g.model_attr, g.user_id, " .
'IF(g.model_price < 1, g.goods_number, IF(g.model_price < 2, wg.region_number, wag.region_number)) AS goods_number, ' .
'IF(g.model_price < 1, g.shop_price, IF(g.model_price < 2, wg.warehouse_price, wag.region_price)) AS shop_price, ' .
"IF(g.model_price < 1, g.promote_price, IF(g.model_price < 2, wg.warehouse_promote_price, wag.region_promote_price)) as promote_price, " .
"g.promote_start_date, g.promote_end_date, g.goods_brief, g.goods_type, g.is_promote " .
"FROM " . $ecs->table('goods') . " AS g " .
$leftJoin .
"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 g.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'];
$goods['warehouse_id'] = $warehouse_id;
$goods['area_id'] = $area_id;
/* 取得会员价格 */
$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);
//ecmoban模板堂 --zhuo satrt
$attr_leftJoin = '';
$select = '';
if($goods['model_attr'] == 1){
$select = " wap.attr_price as warehouse_attr_price, ";
$attr_leftJoin = 'LEFT JOIN ' . $GLOBALS['ecs']->table('warehouse_attr') . " AS wap ON g.goods_attr_id = wap.goods_attr_id AND wap.warehouse_id = '$warehouse_id' ";
}elseif($goods['model_attr'] == 2){
$select = " waa.attr_price as area_attr_price, ";
$attr_leftJoin = 'LEFT JOIN ' . $GLOBALS['ecs']->table('warehouse_area_attr') . " AS waa ON g.goods_attr_id = waa.goods_attr_id AND area_id = '$area_id' ";
}
//ecmoban模板堂 --zhuo end
/* 取得商品属性 */
$sql = "SELECT a.attr_id, a.attr_name, g.goods_attr_id, g.attr_value, " .
$select .
" g.attr_price, a.attr_input_type, a.attr_type " .
"FROM " . $ecs->table('goods_attr') . " AS g " .
"LEFT JOIN" . $ecs->table('attribute') . " AS a ON g.attr_id = a.attr_id " .
$attr_leftJoin .
"WHERE g.goods_id = '$goods_id' ORDER BY g.attr_id ASC";
$goods['attr_list'] = array();
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
//ecmoban模板堂 --zhuo satrt
if($goods['model_attr'] == 1){
$row['attr_price'] = $row['warehouse_attr_price'];
}elseif($goods['model_attr'] == 2){
$row['attr_price'] = $row['area_attr_price'];
}else{
$row['attr_price'] = $row['attr_price'];
}
//ecmoban模板堂 --zhuo end
$goods['attr_list'][$row['attr_id']][] = $row;
}
$goods['attr_list'] = array_values($goods['attr_list']);
//ecmoban模板堂 --zhuo start
if($goods['attr_list']){
foreach($goods['attr_list'] as $attr_key=>$attr_row){
$goods_attr_id .= $attr_row[0]['goods_attr_id'] . ",";
$attr_price += $attr_row[0]['attr_price'];
}
$goods_attr_id = substr($goods_attr_id, 0, -1);
$goods['attr_price'] = $attr_price;
}
$products = get_warehouse_id_attr_number($goods_id, $goods_attr_id, $goods['user_id'], $warehouse_id, $area_id);
$attr_number = $products['product_number'];
if($goods['model_attr'] == 1){
$table_products = "products_warehouse";
$type_files = " and warehouse_id = '$warehouse_id'";
}elseif($goods['model_attr'] == 2){
$table_products = "products_area";
$type_files = " and area_id = '$area_id'";
}else{
$table_products = "products";
$type_files = "";
}
$sql = "SELECT * FROM " .$GLOBALS['ecs']->table($table_products). " WHERE goods_id = '$goods_id'" .$type_files. " LIMIT 0, 1";
$prod = $GLOBALS['db']->getRow($sql);
if(empty($prod)){ //当商品没有属性库存时
$attr_number = $goods['goods_number'];
}
$attr_number = !empty($attr_number) ? $attr_number : 0;
$goods['goods_storage'] = $attr_number;
//ecmoban模板堂 --zhuo end
echo $json->encode($goods);
}else if( $func == 'get_goods_attr_number'){
$products = get_warehouse_id_attr_number($goods_id, $_REQUEST['attr'], $user_id, $warehouse_id, $area_id);
$attr_number = $products['product_number'];
if($model_attr == 1){
$table_products = "products_warehouse";
$type_files = " and warehouse_id = '$warehouse_id'";
}elseif($model_attr == 2){
$table_products = "products_area";
$type_files = " and area_id = '$area_id'";
}else{
$table_products = "products";
$type_files = "";
}
$sql = "SELECT * FROM " .$GLOBALS['ecs']->table($table_products). " WHERE goods_id = '$goods_id'" .$type_files. " LIMIT 0, 1";
$prod = $GLOBALS['db']->getRow($sql);
if(empty($prod)){ //当商品没有属性库存时
$attr_number = $goods_number;
}
$attr_number = !empty($attr_number) ? $attr_number : 0;
$attr_leftJoin = '';
$select = '';
if($model_attr == 1){
$select = " wap.attr_price as warehouse_attr_price, ";
$attr_leftJoin = 'LEFT JOIN ' . $GLOBALS['ecs']->table('warehouse_attr') . " AS wap ON g.goods_attr_id = wap.goods_attr_id AND wap.warehouse_id = '$warehouse_id' ";
}elseif($model_attr == 2){
$select = " waa.attr_price as area_attr_price, ";
$attr_leftJoin = 'LEFT JOIN ' . $GLOBALS['ecs']->table('warehouse_area_attr') . " AS waa ON g.goods_attr_id = waa.goods_attr_id AND area_id = '$area_id' ";
}
$goodsAttr = '';
if(isset($_REQUEST['attr']) && !empty($_REQUEST['attr'])){
$goodsAttr = " and g.goods_attr_id in(" .$_REQUEST['attr']. ") ";
}
/* 取得商品属性 */
$sql = "SELECT a.attr_id, a.attr_name, g.goods_attr_id, g.attr_value, " .
$select .
" g.attr_price, a.attr_input_type, a.attr_type " .
"FROM " . $ecs->table('goods_attr') . " AS g " .
"LEFT JOIN" . $ecs->table('attribute') . " AS a ON g.attr_id = a.attr_id " .
$attr_leftJoin .
"WHERE g.goods_id = '$goods_id' " .$goodsAttr. " ORDER BY g.attr_id ASC";
$goods['attr_list'] = array();
$res = $db->query($sql);
while ($row = $db->fetchRow($res))
{
if($model_attr == 1){
$row['attr_price'] = $row['warehouse_attr_price'];
}elseif($model_attr == 2){
$row['attr_price'] = $row['area_attr_price'];
}else{
$row['attr_price'] = $row['attr_price'];
}
$goods['attr_list'][$row['attr_id']][] = $row;
}
$goods['attr_list'] = array_values($goods['attr_list']);
$goods['attr_price'] = 0;
if($goods['attr_list']){
foreach($goods['attr_list'] as $attr_key=>$attr_row){
$attr_price += $attr_row[0]['attr_price'];
}
$goods['attr_price'] = $attr_price;
}
$goods['goods_id'] = $goods_id;
$goods['warehouse_id'] = $warehouse_id;
$goods['area_id'] = $area_id;
$goods['user_id'] = $user_id;
$goods['attr'] = $_REQUEST['attr'];
$goods['model_attr'] = $model_attr;
$goods['goods_number'] = $goods_number;
$goods['goods_storage'] = $attr_number;
echo $json->encode($goods);
}
}
/*------------------------------------------------------ */
//-- 合并订单查询现有订单列表
/*------------------------------------------------------ */
elseif ($_REQUEST['act'] == 'ajax_merge_order_list')
{
/* 检查权限 */
admin_priv('order_os_edit');
include_once(ROOT_PATH . 'includes/cls_json.php');
$json = new JSON();
$merchant_id = empty($_POST['merchant_id']) ? '' : intval($_POST['merchant_id']);
$store_search = empty($_POST['store_search']) ? -1 : intval($_POST['store_search']);
if($store_search != 1){
$merchant_id = 0;
}
$where = " AND (SELECT og.ru_id FROM " . $GLOBALS['ecs']->table('order_goods') .' as og' . " WHERE og.order_id = o.order_id limit 0, 1) = '$merchant_id' ";
$where .= " AND (select count(*) from " .$GLOBALS['ecs']->table('order_info'). " as oi2 where oi2.main_order_id = o.order_id) = 0 "; //主订单下有子订单时,则主订单不显示
/* 取得满足条件的订单 */
$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 " .
" LEFT JOIN " .$GLOBALS['ecs']->table('order_goods'). " AS og ON o.order_id=og.order_id ".
" LEFT JOIN " .$GLOBALS['ecs']->table('goods'). " AS g ON og.goods_id=g.goods_id ".
"WHERE o.user_id > 0 " . $where .
"AND o.extension_code = '' " . order_query_sql('unprocessed') . " GROUP BY o.order_id";
$order_list = $db->getAll($sql);
$smarty->assign('order_list', $order_list);
make_json_result($smarty->fetch('merge_order_list.htm'));
}
//ecmoban模板堂 --zhuo end
/*------------------------------------------------------ */
//-- 合并订单
/*------------------------------------------------------ */
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']));
$order_id = empty($_GET['order_id']) ? '' : intval($_GET['order_id']);
$warehouse_id = empty($_GET['warehouse_id']) ? '' : intval($_GET['warehouse_id']);
$area_id = empty($_GET['area_id']) ? '' : intval($_GET['area_id']);
$sql = "SELECT ru_id FROM " .$GLOBALS['ecs']->table('order_goods'). " WHERE order_id = '$order_id'";
$ru_id = $GLOBALS['db']->getAll($sql);
$where = '';
if($ru_id){
foreach ($ru_id as $key=>$row){
$ru_str .= $row['ru_id'] . ",";
}
$ru_str = substr($ru_str, 0, -1);
$ru_str = explode(',', $ru_str);
$ru_str = array_unique($ru_str);
$ru_str = implode(',', $ru_str);
$where = " AND user_id IN($ru_str)";
}
$result = array('error'=>0, 'message'=>'', 'content'=>'');
if ($keyword != '')
{
$sql = "SELECT goods_id, goods_name, goods_sn, user_id FROM " . $GLOBALS['ecs']->table('goods') .
" WHERE is_delete = 0" .
" AND is_on_sale = 1" .
$where .
" 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['warehouse_id'] = $warehouse_id;
$result['area_id'] = $area_id;
$result['goodslist'][] = array('goods_id' => $row['goods_id'], 'name' => $row['goods_id'] . ' ' . $row['goods_name'] . ' ' . $row['goods_sn'], 'user_id' => $row['user_id']);
}
}
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);
}
/**
* 修改收货时间
* by Leah
*/ elseif ($_REQUEST['act'] == 'update_info') {
$sign_time = local_strtotime($_REQUEST['time']);
$order_id = $_REQUEST['order_id'];
$sql = 'UPDATE ' . $ecs->table('order_info') . 'set sign_time =' . $sign_time . ' WHERE order_id =' . $order_id;
$db->query($sql);
}
/**
*
* @param type $c_id
* @return type
* by Leah
*/
function cause_info($c_id) {
$sql = "SELECT * FROM " . $GLOBALS['ecs']->table('return_cause') . " WHERE cause_id = " . $c_id;
$res = $GLOBALS['db']->getRow($sql);
if ($res) {
return $res;
} else {
return array();
}
}
/**
* 取得状态列表
* @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']), ACT_OTHER, 1);
$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']), ACT_OTHER, 1);
}
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 || PS_PAYED_PART == $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']); // 取消
}
}
/* 同意申请 */
/*
* by Leah
*/
$list['after_service'] = true;
$list['receive_goods'] = true;
$list['agree_apply'] = true;
$list['refound'] = true;
$list['swapped_out_single'] = true;
$list['swapped_out'] = true;
$list['complete'] = true;
/*
* by Leah
*/
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()
{
//ecmoban模板堂 --zhuo start
$adminru = get_admin_ru_id();
$ruCat = '';
$no_main_order = '';
$where = ' WHERE 1 ';
if($adminru['ru_id'] > 0){
$where .= " AND (SELECT og.ru_id FROM " . $GLOBALS['ecs']->table('order_goods') .' as og' . " WHERE og.order_id = o.order_id limit 0, 1) = '" .$adminru['ru_id']. "' ";
$no_main_order = " and (select count(*) from " .$GLOBALS['ecs']->table('order_info'). " as oi2 where oi2.main_order_id = o.order_id) = 0 "; //主订单下有子订单时,则主订单不显示
}
$noTime = gmtime();
//ecmoban模板堂 --zhuo end
$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['order_country']) ? 0 : intval($_REQUEST['order_country']);
$filter['province'] = empty($_REQUEST['order_province']) ? 0 : intval($_REQUEST['order_province']);
$filter['city'] = empty($_REQUEST['order_city']) ? 0 : intval($_REQUEST['order_city']);
$filter['district'] = empty($_REQUEST['order_district']) ? 0 : intval($_REQUEST['order_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['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']);
//管理员查询的权限 -- 店铺查询 start
$filter['store_search'] = !isset($_REQUEST['store_search']) ? -1 : intval($_REQUEST['store_search']);
$filter['merchant_id'] = isset($_REQUEST['merchant_id']) ? intval($_REQUEST['merchant_id']) : 0;
$filter['store_keyword'] = isset($_REQUEST['store_keyword']) ? trim($_REQUEST['store_keyword']) : '';
$store_search = -1;
$store_where = '';
$store_search_where = '';
if($filter['store_search'] > -1){
if($adminru['ru_id'] == 0){
if($filter['store_search'] > 0){
if($_REQUEST['store_type']){
$store_search_where = "AND msi.shopNameSuffix = '" .$_REQUEST['store_type']. "'";
}
$no_main_order = " and (select count(*) from " .$GLOBALS['ecs']->table('order_info'). " as oi2 where oi2.main_order_id = o.order_id) = 0 "; //主订单下有子订单时,则主订单不显示
if($filter['store_search'] == 1){
$where .= " AND (SELECT og.ru_id FROM " . $GLOBALS['ecs']->table('order_goods') .' as og' . " WHERE og.order_id = o.order_id limit 0, 1) = '" .$filter['merchant_id']. "' ";
}elseif($filter['store_search'] == 2){
$store_where .= " AND msi.rz_shopName LIKE '%" . mysql_like_quote($filter['store_keyword']) . "%'";
}elseif($filter['store_search'] == 3){
$store_where .= " AND msi.shoprz_brandName LIKE '%" . mysql_like_quote($filter['store_keyword']) . "%' " . $store_search_where;
}
if($filter['store_search'] > 1){
$where .= " AND (SELECT og.ru_id FROM " . $GLOBALS['ecs']->table('order_goods') .' as og, ' .
$GLOBALS['ecs']->table('merchants_shop_information') .' as msi ' .
" WHERE og.order_id = o.order_id AND msi.user_id = og.ru_id $store_where limit 0, 1) > 0 ";
}
}else{
$store_search = 0;
}
}
}
//管理员查询的权限 -- 店铺查询 end
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]' ";
}
/* 如果管理员属于某个办事处,只列出这个办事处管辖的订单 */
$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;
}
$groupBy = " group by o.order_id ";
if($store_search == 0 && $adminru['ru_id'] == 0){
$where_store = " AND (SELECT COUNT(*) FROM " .$GLOBALS['ecs']->table('order_goods') ." AS og ". " WHERE o.order_id = og.order_id AND og.ru_id = 0 limit 0,1) > 0 ".
" AND (select count(*) from " .$GLOBALS['ecs']->table('order_info'). " as oi2 where oi2.main_order_id = o.order_id) = 0";
}else{
$where_store = '';
}
/* 记录总数 */
if ($filter['user_name'])
{
$sql = "SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('order_info') . " AS o ,".
$GLOBALS['ecs']->table('users') . " AS u " . $where .$where_store. $no_main_order;
}
else
{
$sql = "SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('order_info') . " AS o ". $where .$where_store. $no_main_order;
}
$record_count = $GLOBALS['db']->getOne($sql);
$filter['record_count'] = $record_count;
$filter['page_count'] = $filter['record_count'] > 0 ? ceil($filter['record_count'] / $filter['page_size']) : 1;
if($store_search == 0 && $adminru['ru_id'] == 0){
$where_store = " AND og.ru_id = 0 ".
" AND (select count(*) from " .$GLOBALS['ecs']->table('order_info'). " as oi2 where oi2.main_order_id = o.order_id) = 0";
}else{
$where_store = '';
}
/* 查询 */
$sql = "SELECT og.ru_id, o.order_id, o.main_order_id, o.order_sn, o.add_time, o.order_status, o.shipping_status, o.order_amount, o.money_paid, o.is_delete," .
"o.shipping_time, o.auto_delivery_time, 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 ".
" LEFT JOIN " .$GLOBALS['ecs']->table('order_goods'). " AS og ON o.order_id=og.order_id ".
$where . $where_store . $no_main_order . $groupBy .
" 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('m-d H:i', $value['add_time']);
//ecmoban模板堂 --zhuo start
$row[$key]['user_name'] = get_shop_name($value['ru_id'], 1);
$order_id = $value['order_id'];
$date = array('order_id');
$order_child = count(get_table_date('order_info', "main_order_id='$order_id'", $date, 1));
$row[$key]['order_child'] = $order_child;
$date = array('order_sn');
$child_list = get_table_date('order_info', "main_order_id='$order_id'", $date, 1);
$row[$key]['child_list'] = $child_list;
//ecmoban模板堂 --zhuo end
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.model_inventory, g.model_attr AS model_attr, g.suppliers_id AS suppliers_id, 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']);
}
}
}
//ecmoban模板堂 --zhuo start
if($row['product_id'] > 0){
$products = get_warehouse_id_attr_number($row['goods_id'], $row['goods_attr_id'], $row['ru_id'], $row['warehouse_id'], $row['area_id'], $row['model_attr']);
$row['storage'] = $products['product_number'];
}else{
if($row['model_inventory'] == 1){
$row['storage'] = get_warehouse_area_goods($row['warehouse_id'], $row['goods_id'], 'warehouse_goods');
}elseif($row['model_inventory'] == 2){
$row['storage'] = get_warehouse_area_goods($row['area_id'], $row['goods_id'], 'warehouse_area_goods');
}
}
//ecmoban模板堂 --zhuo end
$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;
}
/**
* 订单单个商品或货品的已发货数量
*
* @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()
{
//ecmoban模板堂 --zhuo start
$adminru = get_admin_ru_id();
$ruCat = '';
$leftJoin = '';
if($adminru['ru_id'] > 0){
$ruCat = " and og.ru_id = '" .$adminru['ru_id']. "'";
$leftJoin = " LEFT JOIN " .$GLOBALS['ecs']->table("order_info"). " as oi on do.order_id = oi.order_id" .
" LEFT JOIN " .$GLOBALS['ecs']->table("order_goods"). " as og on oi.order_id = og.order_id ";
}
//ecmoban模板堂 --zhuo end
$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']) ? 'do.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 do.order_sn LIKE '%" . mysql_like_quote($filter['order_sn']) . "%'";
}
if ($filter['consignee'])
{
$where .= " AND do.consignee LIKE '%" . mysql_like_quote($filter['consignee']) . "%'";
}
if ($filter['status'] >= 0)
{
$where .= " AND do.status = '" . mysql_like_quote($filter['status']) . "'";
}
if ($filter['delivery_sn'])
{
$where .= " AND do.delivery_sn LIKE '%" . mysql_like_quote($filter['delivery_sn']) . "%'";
}
/* 获取管理员信息 */
$admin_info = admin_info();
/* 如果管理员属于某个办事处,只列出这个办事处管辖的发货单 */
if ($admin_info['agency_id'] > 0)
{
$where .= " AND do.agency_id = '" . $admin_info['agency_id'] . "' ";
}
/* 如果管理员属于某个供货商,只列出这个供货商的发货单 */
if ($admin_info['suppliers_id'] > 0)
{
$where .= " AND do.suppliers_id = '" . $admin_info['suppliers_id'] . "' ";
}
$where .= $ruCat;
/* 分页大小 */
$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') . " as do " .$leftJoin. $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 do.delivery_id, do.delivery_sn, do.order_sn, do.order_id, do.add_time, do.action_user, do.consignee, do.country,
do.province, do.city, do.district, do.tel, do.status, do.update_time, do.email, do.suppliers_id
FROM " . $GLOBALS['ecs']->table("delivery_order") . " as do " .$leftJoin. "
$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']] : '';
$sql = "SELECT ru_id FROM " .$GLOBALS['ecs']->table('order_goods'). " WHERE order_id = '" .$value['order_id']. "' LIMIT 0,1";
$ru_id = $GLOBALS['db']->getOne($sql);
$row[$key]['ru_name'] = get_shop_name($ru_id, 1); //ecmoban模板堂 --zhuo
}
$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()
{
//ecmoban模板堂 --zhuo start
$adminru = get_admin_ru_id();
$ruCat = '';
$leftJoin = '';
if($adminru['ru_id'] > 0){
$ruCat = " and g.user_id = '" .$adminru['ru_id']. "'";
$leftJoin = " LEFT JOIN " .$GLOBALS['ecs']->table("order_info"). " as oi on bo.order_id = oi.order_id" .
" LEFT JOIN " .$GLOBALS['ecs']->table("order_goods"). " as og on oi.order_id = og.order_id" .
" LEFT JOIN " .$GLOBALS['ecs']->table("goods"). " as g on og.goods_id = g.goods_id ";
}
//ecmoban模板堂 --zhuo end
$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']) ? 'bo.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 bo.order_sn LIKE '%" . mysql_like_quote($filter['order_sn']) . "%'";
}
if ($filter['consignee'])
{
$where .= " AND bo.consignee LIKE '%" . mysql_like_quote($filter['consignee']) . "%'";
}
if ($filter['delivery_sn'])
{
$where .= " AND bo.delivery_sn LIKE '%" . mysql_like_quote($filter['delivery_sn']) . "%'";
}
/* 获取管理员信息 */
$admin_info = admin_info();
/* 如果管理员属于某个办事处,只列出这个办事处管辖的发货单 */
if ($admin_info['agency_id'] > 0)
{
$where .= " AND bo.agency_id = '" . $admin_info['agency_id'] . "' ";
}
/* 如果管理员属于某个供货商,只列出这个供货商的发货单 */
if ($admin_info['suppliers_id'] > 0)
{
$where .= " AND bo.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;
}
$where .= $ruCat;
/* 记录总数 */
$sql = "SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('back_order') ." as bo ". $leftJoin . $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 bo.back_id, bo.delivery_sn, bo.order_sn, bo.order_id, bo.add_time, bo.action_user, bo.consignee, bo.country,
bo.province, bo.city, bo.district, bo.tel, bo.status, bo.update_time, bo.email, bo.return_time
FROM " . $GLOBALS['ecs']->table("back_order") ." as bo ". $leftJoin. "
$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);
}
//ecmoban模板堂 --zhuo start
function download_orderlist($result) {
if(empty($result)) {
return i("没有符合您要求的数据!^_^");
}
$data_name = "";
$data_cnt = "";
$adminru = get_admin_ru_id();
if($adminru['ru_id'] < 1){
$data_name = "商家名称,";
$data_cnt = "存在";
}
$data = i('订单号,' .$data_name. '下单会员,下单时间,收货人,联系电话,地址,总金额,应付金额,确认状态,付款状态,发货状态'."\n");
$count = count($result);
for ($i = 0; $i < $count; $i++) {
$order_sn = i($result[$i]['order_sn']);
$order_user = i($result[$i]['buyer']);
$order_time = i($result[$i]['short_order_time']);
$consignee = i($result[$i]['consignee']);
$tel = !empty($result[$i]['mobile']) ? i($result[$i]['mobile']) : i($result[$i]['tel']);
$address = i($result[$i]['address']);
$order_amount = i($result[$i]['order_amount']);
$order_status = i($GLOBALS['_LANG']['os'][$result[$i]['order_status']]);
$ru_name = !empty($data_cnt) ? i($result[$i]['user_name']) . ',' : ''; //商家名称
$pay_status = i($GLOBALS['_LANG']['ps'][$result[$i]['pay_status']]);
$shipping_status = i($GLOBALS['_LANG']['ss'][$result[$i]['shipping_status']]);
$data .= $order_sn . ',' . $ru_name . $order_user . ',' .
$order_time . ',' . $consignee . ',' . $tel . ',' .
$address . ',' . i($result[$i]['total_fee']) . ',' .
$order_amount . ',' . $order_status . ',' .
$pay_status . ',' . $shipping_status . "\n";
}
return $data;
}
function i($strInput) {
return iconv('utf-8','gb2312',$strInput);//页面编码为utf-8时使用,否则导出的中文为乱码
}
function get_warehouse_area_goods($warehouse_id, $goods_id, $table){
$sql = "SELECT region_number FROM " .$GLOBALS['ecs']->table($table). " WHERE region_id = '$warehouse_id' AND goods_id = '$goods_id'";
return $GLOBALS['db']->getOne($sql);
}
//ecmoban模板堂 --zhuo end
?>