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', ''); //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', ''); /* 显示模板 */ 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; $itable($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(',', '
', $delivery['invoice_no']); $invoice_no = trim($invoice_no, '
'); $_delivery['invoice_no'] = $invoice_no; $_delivery['status'] = 0; // 0,为已发货 $query = $db->autoExecute($ecs->table('delivery_order'), $_delivery, 'UPDATE', "delivery_id = $delivery_id", 'SILENT'); if (!$query) { /* 操作失败 */ $links[] = array('text' => $_LANG['delivery_sn'] . $_LANG['detail'], 'href' => 'order.php?act=delivery_info&delivery_id=' . $delivery_id); sys_msg($_LANG['act_false'], 1, $links); } /* 标记订单为已确认 “已发货” */ /* 更新发货时间 */ $order_finish = get_all_delivery_finish($order_id); $shipping_status = ($order_finish == 1) ? SS_SHIPPED : SS_SHIPPED_PART; $arr['shipping_status'] = $shipping_status; $arr['shipping_time'] = GMTIME_UTC; // 发货时间 $arr['invoice_no'] = trim($order['invoice_no'] . '
' . $invoice_no, '
'); 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('
', $order['invoice_no']); $invoice_no_delivery = explode('
', $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('
', $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', ''); /* 显示模板 */ 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', ''); /* 显示模板 */ 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 ''.$_LANG['goods_num_err'] .''; 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(',', '
', $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('
', ',', $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 = ''; $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') . '
'; } 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]
"; $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('
', $order_invoice_no); $delivery_array = explode('
', $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('
', $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 ?>