mirror of
https://gitee.com/ShopeX/OMS
synced 2026-03-23 02:45:33 +08:00
393 lines
14 KiB
PHP
393 lines
14 KiB
PHP
<?php
|
||
/**
|
||
* Copyright © ShopeX (http://www.shopex.cn). All rights reserved.
|
||
* See LICENSE file for license details.
|
||
*/
|
||
/**
|
||
* 分销订单发货回写
|
||
*
|
||
* @author wangbiao@shopex.cn
|
||
* @version 2024.04.24
|
||
*/
|
||
class dealer_ctl_admin_consign extends desktop_controller
|
||
{
|
||
var $name = "平台状态跟踪";
|
||
var $workground = "delivery_center";
|
||
|
||
/**
|
||
* 极速发货
|
||
*
|
||
* @param void
|
||
* @return void
|
||
*/
|
||
|
||
public function index()
|
||
{
|
||
$actions = array();
|
||
$_GET['view'] = intval($_GET['view']);
|
||
|
||
$op_id = kernel::single('desktop_user')->get_id();
|
||
|
||
//view
|
||
switch ($_GET['view']) {
|
||
case '0':
|
||
case '2':
|
||
case '3':
|
||
case '5':
|
||
case '6':
|
||
case '7':
|
||
case '11':
|
||
$actions = array(
|
||
array('label'=>'批量发货', 'submit'=>$this->url.'&act=dailog_delivery_confirm', 'target'=>'dialog::{width:800,height:200,title:\'批量发货\'}"'),
|
||
array('label'=>'已回写成功', 'submit'=>'index.php?app=ome&ctl=admin_consign&act=batch_sync_succ', 'confirm'=>"这些订单系统认为都是在前台(淘宝、京东等)已经发货,请确认这些订单前端已经发货!!!\n\n警告:本操作不会再同步发货状态,并不可恢复,请谨慎使用!!!", 'target' => 'refresh'),
|
||
);
|
||
break;
|
||
case '9':
|
||
$actions = array(
|
||
array('label' => '批量发货', 'submit' => $this->url . 'index.php?app=ome&ctl=admin_consign&act=batch_change_sync', 'confirm' => '你确定要对勾选的订单进行发货操作吗?', 'target' => 'refresh'),
|
||
array('label' => '已回写成功', 'submit' => 'index.php?app=ome&ctl=admin_consign&act=batch_sync_succ', 'confirm' => "这些订单系统认为都是在前台(淘宝、京东等)已经发货,请确认这些订单前端已经发货!!!\n\n警告:本操作不会再同步发货状态,并不可恢复,请谨慎使用!!!", 'target' => 'refresh'),
|
||
);
|
||
break;
|
||
default:
|
||
break;
|
||
}
|
||
|
||
//修改物流
|
||
if($_GET['view'] == '11'){
|
||
$actions[] = array(
|
||
'label' => '批量修改物流公司',
|
||
'submit' => $this->url.'&act=batch_edit_logistics',
|
||
'target' => 'dialog::{width:700,height:300,title:\'批量修改物流公司\'}"',
|
||
);
|
||
}
|
||
|
||
//params
|
||
$params = array(
|
||
'title' => $this->name,
|
||
'actions' => $actions,
|
||
'use_buildin_new_dialog' => false,
|
||
'use_buildin_set_tag' => false,
|
||
'use_buildin_recycle' => false,
|
||
'use_buildin_export' => true,
|
||
'use_buildin_import' => false,
|
||
'use_buildin_filter' => false,
|
||
'use_view_tab' => true,
|
||
'finder_aliasname' => 'order_consign_fast'.$op_id,
|
||
'finder_cols' => '_func_0,column_confirm,order_bn,column_sync_status,column_print_status,logi_id,logi_no,column_deff_time,member_id, ship_name,ship_area,total_amount',
|
||
'base_filter' => $this->getFilters(),
|
||
);
|
||
|
||
$this->finder('dealer_mdl_orders', $params);
|
||
}
|
||
|
||
function _views()
|
||
{
|
||
$orderMdl = app::get('ome')->model('orders');
|
||
|
||
//filter
|
||
$base_filter = $this->getFilters();
|
||
|
||
//menu
|
||
$sub_menu = array(
|
||
0 => array('label' => app::get('base')->_('发货失败'), 'filter' => array('createway'=>'matrix', 'sync'=>'fail'), 'optional' => false,'addon' => '_FILTER_POINT_'),
|
||
2 => array('label' => app::get('base')->_('回写未发起'),'filter' => array('createway'=>'matrix', 'sync'=>'none' ,'ship_status' => '1'),'optional' => false),
|
||
3 => array('label' => app::get('base')->_('发货中'), 'filter' => array('createway'=>'matrix','sync' => 'run'), 'optional' => false),
|
||
8 => array('label' => app::get('base')->_('发货成功'), 'filter' => array('createway'=>'matrix', 'sync'=>'succ'), 'optional' => false),
|
||
10 => array('label' => app::get('base')->_('换货订单回写失败'),'filter' => array('createway' => array('after'),'sync'=>'fail'),'optional' => false),
|
||
11 => array('label' => app::get('base')->_('物流错误'), 'filter' => array('createway'=>'matrix', 'sync'=>'fail', 'sync_fail_type'=>'logistics'), 'optional'=>false),
|
||
);
|
||
|
||
//format
|
||
foreach ($sub_menu as $k => $v)
|
||
{
|
||
if (isset($v['filter'])){
|
||
$v['filter'] = array_merge($base_filter, $v['filter']);
|
||
}
|
||
|
||
$sub_menu[$k]['filter'] = $v['filter'] ? $v['filter'] : null;
|
||
$sub_menu[$k]['addon'] = $v['addon'] ? $v['addon'] : $orderMdl->viewcount($v['filter']);
|
||
$sub_menu[$k]['href'] = 'index.php?app='. $_GET['app'] .'&ctl='. $_GET['ctl'] .'&act='. $_GET['act'] .'&flt='. $_GET['flt'] .'&view='. $k;
|
||
}
|
||
|
||
return $sub_menu;
|
||
}
|
||
|
||
/**
|
||
* 公共filter条件
|
||
*
|
||
* @return array
|
||
*/
|
||
public function getFilters()
|
||
{
|
||
$base_filter = array();
|
||
$base_filter['status'] = array('active', 'finish');
|
||
$base_filter['order_confirm_filter'] = "sdb_ome_orders.ship_status IN('1', '2') AND logi_no <> ''";
|
||
|
||
//check shop permission
|
||
$organization_permissions = kernel::single('desktop_user')->get_organization_permission();
|
||
if($organization_permissions){
|
||
$base_filter['org_id'] = $organization_permissions;
|
||
}
|
||
|
||
|
||
|
||
//分销订单
|
||
//@todo:写个公共方法获取当前用户的组织权限和所有贸易公司ID;
|
||
$base_filter['betc_id|than'] = 0; //贸易公司ID
|
||
$base_filter['cos_id|than'] = 0; //组织权限
|
||
|
||
|
||
return $base_filter;
|
||
}
|
||
|
||
/**
|
||
* 批量消除冲突
|
||
*
|
||
* @param void
|
||
* @return void
|
||
*/
|
||
function batch_sync_succ()
|
||
{
|
||
$this->begin('');
|
||
$ids = $_REQUEST['order_id'];
|
||
if (!empty($ids)) {
|
||
$orderObj = app::get('ome')->model('orders');
|
||
$data = array('sync'=>'succ','sync_fail_type'=>'none');
|
||
$filter = array('order_id'=>$ids,'createway' => 'matrix');
|
||
$orderObj->update($data,$filter);
|
||
|
||
//记录日志
|
||
$logObj = app::get('ome')->model('operation_log');
|
||
$logObj->batch_write_log('order_modify@ome',$filter,'手动设为同步成功',time());
|
||
}
|
||
$this->end(true, '命令已经被成功发送!');
|
||
}
|
||
|
||
/**
|
||
* 批量发货
|
||
*
|
||
* @param void
|
||
* @return void
|
||
*/
|
||
function batch_sync()
|
||
{
|
||
$this->begin('');
|
||
kernel::database()->exec('commit');
|
||
|
||
$ids = $_REQUEST['order_id'];
|
||
$deliveryObj = app::get('ome')->model('delivery');
|
||
if (!empty($ids)) {
|
||
|
||
kernel::single('ome_event_trigger_shop_delivery')->delivery_confirm_retry($ids);
|
||
}
|
||
$this->end(true, '命令已经被成功发送!!');
|
||
}
|
||
|
||
/**
|
||
* 天猫换货订单 发货重试
|
||
* @DateTime 2018-02-07T11:50:29+0800
|
||
* @return
|
||
*/
|
||
public function batch_change_sync()
|
||
{
|
||
$this->begin('');
|
||
kernel::database()->exec('commit');
|
||
|
||
$ids = $_REQUEST['order_id'];
|
||
if (!empty($ids)) {
|
||
foreach($ids as $order_id){
|
||
kernel::single('ome_service_aftersale')->exchange_consigngoods($order_id);
|
||
}
|
||
}
|
||
|
||
$this->end(true, '命令已经被成功发送!!');
|
||
}
|
||
|
||
public function dailog_delivery_confirm()
|
||
{
|
||
$_POST['sync'] = ['fail', 'run', 'none'];
|
||
|
||
$orderMdl = app::get('ome')->model('orders');
|
||
$order_list = $orderMdl->getList('order_id', $_POST);
|
||
|
||
$order_id = array_column($order_list, 'order_id');
|
||
|
||
$this->pagedata['GroupList'] = json_encode($order_id);
|
||
|
||
$this->pagedata['request_url'] = $this->url . '&act=ajax_delivery_confirm';
|
||
|
||
parent::dialog_batch();
|
||
}
|
||
|
||
/**
|
||
* Ajax重试回传平台发货状态
|
||
*
|
||
* @return void
|
||
*/
|
||
public function ajax_delivery_confirm()
|
||
{
|
||
$order_id = explode(',', $_POST['primary_id']);
|
||
if (!$order_id) { echo 'Error: 请先选择订单';exit;}
|
||
|
||
$retArr = array(
|
||
'itotal' => count($order_id),
|
||
'isucc' => count($order_id),
|
||
'ifail' => 0,
|
||
'err_msg' => array(),
|
||
);
|
||
|
||
kernel::single('ome_event_trigger_shop_delivery')->delivery_confirm_retry($order_id);
|
||
|
||
echo json_encode($retArr),'ok.';exit;
|
||
}
|
||
|
||
/**
|
||
* 批量修改物流公司
|
||
*/
|
||
public function batch_edit_logistics()
|
||
{
|
||
$orderObj = app::get('ome')->model('orders');
|
||
|
||
$ids = $_POST['order_id'];
|
||
|
||
//check
|
||
if($_POST['isSelectedAll'] == '_ALL_'){
|
||
die('不能使用全选功能,每次最多选择500条!');
|
||
}
|
||
|
||
if(count($ids) > 500){
|
||
die('每次最多只能选择500条!');
|
||
}
|
||
|
||
//物流公司列表
|
||
$sql = "SELECT corp_id,type,name FROM sdb_ome_dly_corp WHERE 1";
|
||
$tempList = $orderObj->db->select($sql);
|
||
|
||
$logiList = array();
|
||
foreach ($tempList as $key => $val)
|
||
{
|
||
if(in_array($val['type'], array('o2o_pickup', 'o2o_ship'))){
|
||
continue;
|
||
}
|
||
|
||
$logiList[] = $val;
|
||
}
|
||
|
||
//pagedata
|
||
$this->pagedata['logiList'] = $logiList;
|
||
$this->pagedata['GroupList'] = $ids;
|
||
$this->pagedata['request_url'] = 'index.php?app=ome&ctl=admin_consign&act=ajaxEditLogistics';
|
||
$this->pagedata['custom_html'] = $this->fetch('admin/order/edit_logistics.html');
|
||
|
||
//调用desktop公用进度条
|
||
parent::dialog_batch('ome_mdl_orders', false, 10, 10);
|
||
}
|
||
|
||
/**
|
||
* 修改物流公司
|
||
**/
|
||
public function ajaxEditLogistics()
|
||
{
|
||
$orderObj = app::get('ome')->model('orders');
|
||
$operLogObj = app::get('ome')->model('operation_log');
|
||
|
||
//获取订单号
|
||
parse_str($_POST['primary_id'], $postdata);
|
||
if(!$postdata){
|
||
echo 'Error: 请先选择订单';
|
||
exit;
|
||
}
|
||
|
||
//物流公司ID
|
||
$corp_id = $_POST['corp_id'];
|
||
if(empty($corp_id)){
|
||
echo 'Error: 请先选择物流公司';
|
||
exit;
|
||
}
|
||
|
||
$retArr = array(
|
||
'itotal' => 0,
|
||
'isucc' => 0,
|
||
'ifail' => 0,
|
||
'err_msg' => array(),
|
||
);
|
||
|
||
//物流公司列表
|
||
$sql = "SELECT corp_id,type,name FROM sdb_ome_dly_corp WHERE corp_id=".$corp_id;
|
||
$corpInfo = $orderObj->db->selectrow($sql);
|
||
if(empty($corpInfo)){
|
||
echo 'Error: 没有找到物流公司';
|
||
exit;
|
||
}
|
||
|
||
//订单列表
|
||
$list = $orderObj->getList('order_id,order_bn,ship_status,createway,sync', $postdata['f'], $postdata['f']['offset'], $postdata['f']['limit']);
|
||
|
||
//count
|
||
$retArr['itotal'] = count($list);
|
||
|
||
foreach ((array)$list as $key => $val)
|
||
{
|
||
$order_id = $val['order_id'];
|
||
|
||
//check
|
||
if($val['ship_status'] != '1'){
|
||
//error
|
||
$retArr['ifail'] += 1;
|
||
$retArr['err_msg'][] = $val['order_bn'].'订单不是已发货状态';
|
||
|
||
continue;
|
||
}
|
||
|
||
if($val['createway'] != 'matrix'){
|
||
//error
|
||
$retArr['ifail'] += 1;
|
||
$retArr['err_msg'][] = $val['order_bn'].'订单不是平台下来的';
|
||
|
||
continue;
|
||
}
|
||
|
||
if($val['sync'] != 'fail'){
|
||
//error
|
||
$retArr['ifail'] += 1;
|
||
$retArr['err_msg'][] = $val['order_bn'].'订单不是回传失败的状态';
|
||
|
||
continue;
|
||
}
|
||
|
||
//关联发货单(只获取已发货的发货单)
|
||
$sql = "SELECT b.delivery_id FROM sdb_ome_delivery_order AS a ";
|
||
$sql .= " LEFT JOIN sdb_ome_delivery AS b ON a.delivery_id=b.delivery_id WHERE a.order_id=". $order_id ." AND b.status='succ'";
|
||
$deliveryList = $orderObj->db->select($sql);
|
||
if(empty($deliveryList)){
|
||
//error
|
||
$retArr['ifail'] += 1;
|
||
$retArr['err_msg'][] = $val['order_bn'].'没有找到已发货的发货单';
|
||
|
||
continue;
|
||
}
|
||
|
||
$delivery_ids = array_column($deliveryList, 'delivery_id');
|
||
|
||
//[发货单]更新物流公司
|
||
$update_sql = "UPDATE sdb_ome_delivery SET logi_id='%d', logi_name='%s' WHERE delivery_id IN(". implode(',', $delivery_ids) .")";
|
||
$update_sql = sprintf($update_sql, $corpInfo['corp_id'], $corpInfo['name']);
|
||
$orderObj->db->exec($update_sql);
|
||
|
||
//[订单]更新物流公司
|
||
$update_sql = "UPDATE sdb_ome_orders SET logi_id='%d' WHERE order_id='%d'";
|
||
$update_sql = sprintf($update_sql, $corpInfo['corp_id'], $order_id);
|
||
$orderObj->db->exec($update_sql);
|
||
|
||
//log
|
||
$operLogObj->write_log('order_edit@ome', $order_id, '修改订单和发货单的物流公司为:'.$corpInfo['name']);
|
||
|
||
//succ
|
||
$retArr['isucc'] += 1;
|
||
}
|
||
|
||
echo json_encode($retArr),'ok.';
|
||
exit;
|
||
}
|
||
}
|