zx/app/controller/merchant/store/order/Order.php

451 lines
15 KiB
PHP
Raw Normal View History

2024-07-02 15:32:59 +08:00
<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
namespace app\controller\merchant\store\order;
use app\common\repositories\store\ExcelRepository;
use app\common\repositories\store\order\MerchantReconciliationRepository;
use app\common\repositories\store\order\StoreOrderRepository;
use crmeb\exceptions\UploadException;
use crmeb\jobs\BatchDeliveryJob;
use crmeb\services\ExcelService;
use think\App;
use crmeb\basic\BaseController;
use app\common\repositories\store\order\StoreOrderRepository as repository;
use think\facade\Queue;
class Order extends BaseController
{
protected $repository;
/**
* Product constructor.
* @param App $app
* @param repository $repository
*/
public function __construct(App $app, repository $repository)
{
parent::__construct($app);
$this->repository = $repository;
}
public function title()
{
$where = $this->request->params(['status', 'date', 'order_sn', 'username', 'order_type', 'keywords', 'order_id', 'activity_type','filter_delivery','filter_product','delivery_id']);
$where['mer_id'] = $this->request->merId();
$pay_type = $this->request->param('pay_type','');
if ($pay_type != '') $where['pay_type'] = $this->repository::PAY_TYPE_FILTEER[$pay_type];
return app('json')->success($this->repository->getStat($where, $where['status']));
}
/**
* 订单列表
* @return mixed
* @author Qinii
*/
public function lst()
{
[$page, $limit] = $this->getPage();
$where = $this->request->params(['status', 'date', 'order_sn', 'username', 'order_type', 'keywords', 'order_id', 'activity_type', 'group_order_sn', 'store_name','filter_delivery','filter_product','delivery_id']);
$where['mer_id'] = $this->request->merId();
$pay_type = $this->request->param('pay_type','');
if ($pay_type != '') $where['pay_type'] = $this->repository::PAY_TYPE_FILTEER[$pay_type];
return app('json')->success($this->repository->merchantGetList($where, $page, $limit));
}
public function takeTitle()
{
$where = $this->request->params(['date', 'order_sn', 'username', 'keywords']);
$where['take_order'] = 1;
$where['status'] = -1;
$where['verify_date'] = $where['date'];
unset($where['date']);
$where['mer_id'] = $this->request->merId();
return app('json')->success($this->repository->getStat($where, ''));
}
/**
* TODO 自提订单列表
* @return mixed
* @author Qinii
* @day 2020-08-17
*/
public function takeLst()
{
[$page, $limit] = $this->getPage();
$where = $this->request->params(['date', 'order_sn', 'username', 'keywords']);
$where['take_order'] = 1;
$where['status'] = -1;
$where['verify_date'] = $where['date'];
unset($where['date']);
$where['mer_id'] = $this->request->merId();
return app('json')->success($this->repository->merchantGetList($where, $page, $limit));
}
/**
* 订单头部统计
* @return mixed
* @author Qinii
*/
public function chart()
{
return app('json')->success($this->repository->OrderTitleNumber($this->request->merId(), null));
}
/**
* TODO 自提订单头部统计
* @return mixed
* @author Qinii
* @day 2020-08-17
*/
public function takeChart()
{
return app('json')->success($this->repository->OrderTitleNumber($this->request->merId(), 1));
}
/**
* TODO 订单类型
* @return mixed
* @author Qinii
* @day 2020-08-15
*/
public function orderType()
{
$where['mer_id'] = $this->request->merId();
return app('json')->success($this->repository->orderType($where));
}
/**
* @param $id
* @return mixed
* @author Qinii
*/
public function deliveryForm($id)
{
$data = $this->repository->getWhere(['order_id' => $id, 'mer_id' => $this->request->merId(), 'is_del' => 0]);
if (!$data) return app('json')->fail('数据不存在');
if (!$data['paid']) return app('json')->fail('订单未支付');
if (!in_array($data['status'], [0, 1])) return app('json')->fail('订单状态错误');
return app('json')->success(formToData($this->repository->sendProductForm($id, $data)));
}
/**
* TODO 发货
* @param $id
* @return mixed
* @author Qinii
*/
public function delivery($id)
{
$type = $this->request->param('delivery_type');
$split = $this->request->params(['is_split',['split',[]]]);
if (!$this->repository->merDeliveryExists($id, $this->request->merId()))
return app('json')->fail('订单信息或状态错误');
switch ($type)
{
case 3: //虚拟发货
$data = $this->request->params([
'delivery_type',
'remark',
]);
$data['delivery_name'] = '';
$data['delivery_id'] = '';
$method = 'delivery';
break;
case 4: //电子面单
if (!systemConfig('crmeb_serve_dump'))
return app('json')->fail('电子面单功能未开启');
$data = $this->request->params([
'delivery_type',
'delivery_name',
'from_name',
'from_tel',
'from_addr',
'temp_id',
'remark',
]);
if (!$data['from_name'] ||
!$data['delivery_name'] ||
!$data['from_tel'] ||
!$data['from_addr'] ||
!$data['temp_id']
)
return app('json')->fail('填写配送信息');
$method = 'dump';
break;
case 5: //同城配送
if (systemConfig('delivery_status') != 1)
return app('json')->fail('未开启同城配送');
$data = $this->request->params(['delivery_type', 'station_id', 'mark', ['cargo_weight',0], 'remark',]);
if ($data['cargo_weight'] < 0) return app('json')->fail('包裹重量能为负数');
if (!$data['station_id']) return app('json')->fail('请选择门店');
$method = 'cityDelivery';
break;
default: //快递
$data = $this->request->params(['delivery_type', 'delivery_name', 'delivery_id', 'remark',]);
if (!$data['delivery_type'] || !$data['delivery_name'] || !$data['delivery_id'])
return app('json')->fail('填写配送信息');
$method = 'delivery';
break;
}
$res = $this->repository->runDelivery($id,$this->request->merId(), $data, $split, $method);
return app('json')->success('发货成功',$res);
}
/**
* TODO
* @return \think\response\Json
* @author Qinii
* @day 7/26/21
*/
public function batchDelivery()
{
$params = $this->request->params([
'order_id',
'delivery_id',
'delivery_type',
'delivery_name',
'remark',
['select_type', 'select'],
['where', []]
]);
if (!in_array($params['select_type'], ['all', 'select'])) return app('json')->fail('选择了类型错误');
if (!in_array($params['delivery_type'], [2, 3])) return app('json')->fail('发货类型错误');
if ($params['select_type'] == 'select' && !$params['order_id']) return app('json')->fail('需要订单ID');
if ($params['select_type'] == 'all' && empty($params['where'])) return app('json')->fail('需要搜索条件');
// $this->repository->batchDelivery($this->request->merId(),$params);
Queue::push(BatchDeliveryJob::class, [
'mer_id' => $this->request->merId(),
'data' => $params
]);
return app('json')->success('以开始批量发货,请稍后查看');
}
/**
* TODO 改价form
* @param $id
* @return mixed
* @author Qinii
* @day 2020-06-11
*/
public function updateForm($id)
{
if (!$this->repository->merStatusExists($id, $this->request->merId()))
return app('json')->fail('订单信息或状态错误');
return app('json')->success(formToData($this->repository->form($id)));
}
/**
* TODO 改价
* @param $id
* @return mixed
* @author Qinii
* @day 2020-06-11
*/
public function update($id)
{
$data = $this->request->params(['total_price', 'pay_postage']);
if ($data['total_price'] < 0 || $data['pay_postage'] < 0)
return app('json')->fail('金额不可未负数');
if (!$this->repository->merStatusExists($id, $this->request->merId()))
return app('json')->fail('订单信息或状态错误');
$this->repository->eidt($id, $data);
return app('json')->success('修改成功');
}
/**
* @param $id
* @return mixed
* @author Qinii
* @day 2020-06-11
*/
public function detail($id)
{
$data = $this->repository->getOne($id, $this->request->merId());
if (!$data) return app('json')->fail('数据不存在');
return app('json')->success($data);
}
/**
* @param $id
* @return mixed
* @author Qinii
* @day 2020-06-11
*/
public function status($id)
{
[$page, $limit] = $this->getPage();
$where = $this->request->params(['date','user_type']);
$where['id'] = $id;
if (!$this->repository->getOne($id, $this->request->merId()))
return app('json')->fail('数据不存在');
return app('json')->success($this->repository->getOrderStatus($where, $page, $limit));
}
/**
* @param $id
* @return mixed
* @author Qinii
* @day 2020-06-11
*/
public function remarkForm($id)
{
return app('json')->success(formToData($this->repository->remarkForm($id)));
}
/**
* @param $id
* @return mixed
* @author Qinii
* @day 2020-06-11
*/
public function remark($id)
{
if (!$this->repository->getOne($id, $this->request->merId()))
return app('json')->fail('数据不存在');
$data = $this->request->params(['remark']);
$this->repository->update($id, $data);
return app('json')->success('备注成功');
}
/**
* 核销
* @param $code
* @author xaboy
* @day 2020/8/15
*/
public function verify($id)
{
$data = $this->request->params(['data','verify_code']);
$this->repository->verifyOrder($id, $this->request->merId(), $data);
return app('json')->success('订单核销成功');
}
public function verifyDetail($code)
{
$order = $this->repository->codeByDetail($code);
if (!$order) return app('json')->fail('订单不存在');
return app('json')->success($order);
}
/**
* @param $id
* @return mixed
* @author Qinii
* @day 2020-06-11
*/
public function delete($id)
{
if (!$this->repository->userDelExists($id, $this->request->merId()))
return app('json')->fail('订单信息或状态错误');
$this->repository->merDelete($id);
return app('json')->success('删除成功');
}
/**
* TODO 快递查询
* @param $id
* @return mixed
* @author Qinii
* @day 2020-06-25
*/
public function express($id)
{
return app('json')->success($this->repository->express($id, $this->request->merId()));
}
/**
* TODO
* @param $id
* @return mixed
* @author Qinii
* @day 2020-07-30
*/
public function reList($id)
{
[$page, $limit] = $this->getPage();
$make = app()->make(MerchantReconciliationRepository::class);
if (!$make->getWhereCount(['mer_id' => $this->request->merId(), 'reconciliation_id' => $id]))
return app('json')->fail('数据不存在');
$where = ['reconciliation_id' => $id, 'type' => 0];
return app('json')->success($this->repository->reconList($where, $page, $limit));
}
/**
* TODO 导出文件
* @author Qinii
* @day 2020-07-30
*/
public function excel()
{
[$page, $limit] = $this->getPage();
$where = $this->request->params(['status', 'date', 'order_sn', 'order_type', 'username', 'keywords', 'take_order', 'order_id', 'activity_type', 'group_order_sn', 'store_name', 'filter_delivery', 'filter_product', 'pay_type']);
if ($where['pay_type'] != '') $where['pay_type'] = $this->repository::PAY_TYPE_FILTEER[$where['pay_type']];
if ($where['take_order']) {
$where['status'] = -1;
$where['verify_date'] = $where['date'];
unset($where['date']);
unset($where['order_type']);
}
$where['mer_id'] = $this->request->merId();
$data = app()->make(ExcelService::class)->order($where,$page,$limit);
return app('json')->success($data);
}
/**
* TODO 打印小票
* @param $id
* @return mixed
* @author Qinii
* @day 2020-07-30
*/
public function printer($id)
{
$merId = $this->request->merId();
if (!$this->repository->getWhere(['order_id' => $id, 'mer_id' => $merId]))
return app('json')->fail('数据不存在');
$this->repository->batchPrinter($id, $merId);
return app('json')->success('打印成功');
}
/**
* TODO 导出发货单
* @return \think\response\Json
* @author Qinii
* @day 3/13/21
*/
public function deliveryExport()
{
$where = $this->request->params(['username', 'date', 'activity_type', 'order_type', 'username', 'keywords', 'id']);
$where['order_ids'] = $this->request->param('ids');
$where['mer_id'] = $this->request->merId();
$where['status'] = 0;
$where['paid'] = 1;
$make = app()->make(StoreOrderRepository::class);
if (is_array($where['id'])) $where['order_ids'] = $where['id'];
$count = $make->search($where)->count();
if (!$count) return app('json')->fail('没有可导出数据');
[$page, $limit] = $this->getPage();
$data = app()->make(ExcelService::class)->delivery($where,$page,$limit);
return app('json')->success($data);
}
public function childrenList($id)
{
$data = $this->repository->childrenList($id, $this->request->merId());
return app('json')->success($data);
}
}