123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335 |
- <?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\api\server;
- use app\common\repositories\delivery\DeliveryStationRepository;
- use app\common\repositories\store\order\StoreOrderRepository;
- use app\common\repositories\store\order\StoreRefundOrderRepository;
- use app\common\repositories\store\service\StoreServiceRepository;
- use app\controller\merchant\Common;
- use crmeb\basic\BaseController;
- use think\App;
- use think\exception\HttpResponseException;
- use think\exception\ValidateException;
- use think\facade\Db;
- use think\response\Json;
- class StoreOrder extends BaseController
- {
- public function __construct(App $app)
- {
- parent::__construct($app);
- }
- public function orderStatistics($merId, StoreOrderRepository $repository)
- {
- $order = $repository->OrderTitleNumber($merId, null);
- $order['refund'] = app()->make(StoreRefundOrderRepository::class)->getWhereCount(['is_system_del' => 0, 'mer_id' => $merId]);
- $common = app()->make(Common::class);
- $data = [];
- $data['today'] = $common->mainGroup('today', $merId);
- $data['yesterday'] = $common->mainGroup('yesterday', $merId);
- $data['month'] = $common->mainGroup('month', $merId);
- return app('json')->success(compact('order', 'data'));
- }
- public function orderDetail($merId, StoreOrderRepository $repository)
- {
- [$page, $limit] = $this->getPage();
- list($start, $stop) = $this->request->params([
- ['start', strtotime(date('Y-m'))],
- ['stop', time()],
- ], true);
- if ($start == $stop) return app('json')->fail('参数有误');
- if ($start > $stop) {
- $middle = $stop;
- $stop = $start;
- $start = $middle;
- }
- $where = $this->request->has('start') ? ['dateRange' => compact('start', 'stop')] : [];
- $list = $repository->orderGroupNumPage($where, $page, $limit, $merId);
- return app('json')->success($list);
- }
- public function orderList($merId, StoreOrderRepository $repository)
- {
- [$page, $limit] = $this->getPage();
- $where['status'] = $this->request->param('status');
- $where['is_verify'] = $this->request->param('is_verify');
- $where['search'] = $this->request->param('store_name');
- $where['mer_id'] = $merId;
- $where['is_del'] = 0;
- if($where['status'] == 2) $where['order_type'] = 0;
- return app('json')->success($repository->merchantGetList($where, $page, $limit));
- }
- public function order($merId, $id, StoreOrderRepository $repository)
- {
- $detail = $repository->getDetail($id);
- if (!$detail)
- return app('json')->fail('订单不存在');
- if ($detail['mer_id'] != $merId)
- return app('json')->fail('没有权限');
- return app('json')->success($detail->toArray());
- }
- protected function checkOrderAuth($merId, $id)
- {
- if (!app()->make(StoreOrderRepository::class)->existsWhere(['mer_id' => $merId, 'order_id' => $id]))
- throw new ValidateException('没有权限');
- }
- public function mark($merId, $id, StoreOrderRepository $repository)
- {
- $this->checkOrderAuth($merId, $id);
- $data = $this->request->params(['remark']);
- $repository->update($id, $data);
- return app('json')->success('备注成功');
- }
- public function price($merId, $id, StoreOrderRepository $repository)
- {
- $this->checkOrderAuth($merId, $id);
- $data = $this->request->params(['total_price', 'pay_postage']);
- if ($data['total_price'] < 0 || $data['pay_postage'] < 0)
- return app('json')->fail('金额不可未负数');
- if (!$repository->merStatusExists((int)$id, $merId))
- return app('json')->fail('订单信息或状态错误');
- $repository->eidt($id, $data);
- return app('json')->success('修改成功');
- }
- /**
- * TODO 发货操作
- * @param $merId
- * @param $id
- * @param StoreOrderRepository $repository
- * @return Json
- * @author Qinii
- * @day 6/1/22
- */
- public function delivery($merId, $id, StoreOrderRepository $repository)
- {
- $this->checkOrderAuth($merId, $id);
- $type = $this->request->param('delivery_type');
- $split = $this->request->params(['is_split',['split',[]]]);
- if (!$repository->merDeliveryExists($id, $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_type',
- 'delivery_name',
- 'delivery_id',
- 'remark',
- ]);
- if (!$data['delivery_type'] || !$data['delivery_name'] || !$data['delivery_id'])
- return app('json')->fail('填写配送信息');
- $method = 'delivery';
- break;
- }
- $repository->runDelivery($id,$merId, $data, $split, $method);
- return app('json')->success('发货成功');
- }
- public function payPrice($merId, StoreOrderRepository $repository)
- {
- list($start, $stop, $month) = $this->request->params([
- ['start', strtotime(date('Y-m'))],
- ['stop', time()],
- 'month'
- ], true);
- if ($month) {
- $start = date('Y/m/d', strtotime(getStartModelTime('month')));
- $stop = date('Y/m/d H:i:s', strtotime('+ 1day'));
- $front = date('Y/m/d', strtotime('first Day of this month', strtotime('-1 day', strtotime('first Day of this month'))));
- $end = date('Y/m/d H:i:s', strtotime($start . ' -1 second'));
- } else {
- if ($start == $stop) return app('json')->fail('参数有误');
- if ($start > $stop) {
- $middle = $stop;
- $stop = $start;
- $start = $middle;
- }
- $space = bcsub($stop, $start, 0);//间隔时间段
- $front = bcsub($start, $space, 0);//第一个时间段
- $front = date('Y/m/d H:i:s', $front);
- $start = date('Y/m/d H:i:s', $start);
- $stop = date('Y/m/d H:i:s', $stop);
- $end = date('Y/m/d H:i:s', strtotime($start . ' -1 second'));
- }
- $frontPrice = $repository->dateOrderPrice($front . '-' . $end, $merId);
- $afterPrice = $repository->dateOrderPrice($start . '-' . date('Y/m/d H:i:s', strtotime($stop . '-1 second')), $merId);
- $chartInfo = $repository->chartTimePrice($start, date('Y/m/d H:i:s', strtotime($stop . '-1 second')), $merId);
- $data['chart'] = $chartInfo;//营业额图表数据
- $data['time'] = $afterPrice;//时间区间营业额
- $increase = (float)bcsub((string)$afterPrice, (string)$frontPrice, 2); //同比上个时间区间增长营业额
- $growthRate = abs($increase);
- if ($growthRate == 0) $data['growth_rate'] = 0;
- else if ($frontPrice == 0) $data['growth_rate'] = bcmul($growthRate, 100, 0);
- else $data['growth_rate'] = (int)bcmul((string)bcdiv((string)$growthRate, (string)$frontPrice, 2), '100', 0);//时间区间增长率
- $data['increase_time'] = abs($increase); //同比上个时间区间增长营业额
- $data['increase_time_status'] = $increase >= 0 ? 1 : 2; //同比上个时间区间增长营业额增长 1 减少 2
- return app('json')->success($data);
- }
- /**
- * @param StoreOrderRepository $repository
- * @return Json
- * @author xaboy
- * @day 2020/8/27
- */
- public function payNumber($merId, StoreOrderRepository $repository)
- {
- list($start, $stop, $month) = $this->request->params([
- ['start', strtotime(date('Y-m'))],
- ['stop', time()],
- 'month'
- ], true);
- if ($month) {
- $start = date('Y/m/d', strtotime(getStartModelTime('month')));
- $stop = date('Y/m/d H:i:s', strtotime('+ 1day'));
- $front = date('Y/m/d', strtotime('first Day of this month', strtotime('-1 day', strtotime('first Day of this month'))));
- $end = date('Y/m/d H:i:s', strtotime($start . ' -1 second'));
- } else {
- if ($start == $stop) return app('json')->fail('参数有误');
- if ($start > $stop) {
- $middle = $stop;
- $stop = $start;
- $start = $middle;
- }
- $space = bcsub($stop, $start, 0);//间隔时间段
- $front = bcsub($start, $space, 0);//第一个时间段
- $front = date('Y/m/d H:i:s', $front);
- $start = date('Y/m/d H:i:s', $start);
- $stop = date('Y/m/d H:i:s', $stop);
- $end = date('Y/m/d H:i:s', strtotime($start . ' -1 second'));
- }
- $frontNumber = $repository->dateOrderNum($front . '-' . $end, $merId);
- $afterNumber = $repository->dateOrderNum($start . '-' . date('Y/m/d H:i:s', strtotime($stop . '-1 second')), $merId);
- $chartInfo = $repository->chartTimeNum($start . '-' . date('Y/m/d H:i:s', strtotime($stop . '-1 second')), $merId);
- $data['chart'] = $chartInfo;//订单数图表数据
- $data['time'] = $afterNumber;//时间区间订单数
- $increase = $afterNumber - $frontNumber; //同比上个时间区间增长订单数
- $growthRate = abs($increase);
- if ($growthRate == 0) $data['growth_rate'] = 0;
- else if ($frontNumber == 0) $data['growth_rate'] = bcmul($growthRate, 100, 0);
- else $data['growth_rate'] = (int)bcmul((string)bcdiv((string)$growthRate, (string)$frontNumber, 2), '100', 0);//时间区间增长率
- $data['increase_time'] = abs($increase); //同比上个时间区间增长营业额
- $data['increase_time_status'] = $increase >= 0 ? 1 : 2; //同比上个时间区间增长营业额增长 1 减少 2
- return app('json')->success($data);
- }
- public function getFormData($merId)
- {
- $config = [
- 'mer_from_com',
- 'mer_from_name',
- 'mer_from_tel',
- 'mer_from_addr',
- 'mer_config_siid',
- 'mer_config_temp_id'
- ];
- $data = merchantConfig($merId,$config);
- return app('json')->success($data);
- }
- public function getDeliveryConfig()
- {
- $data = systemConfig(['crmeb_serve_dump','delivery_status']);
- return app('json')->success($data);
- }
- public function getDeliveryOptions($merId, DeliveryStationRepository $repository)
- {
- if (!systemConfig('delivery_status')) {
- return app('json')->success([]);
- }
- $where = [
- 'status' => 1,
- 'mer_id' => $merId,
- 'type' => systemConfig('delivery_type'),
- ];
- $data = $repository->getOptions($where)->toArray();
- $type = systemConfig('delivery_type') == 1 ? 'UU' : '达达';
- if (empty($data)) return app('json')->fail('请前往商户后台添加'.$type.'发货点');
- return app('json')->success($data);
- }
- public function verify($merId,$id,StoreOrderRepository $orderRepository)
- {
- $order = $orderRepository->getWhere(['order_id' => $id,'mer_id' => $merId]);
- if (!$order) return app('json')->fail('数据不存在');
- $orderRepository->verifyOrder($order->verify_code, $merId, 0);
- return app('json')->success('订单核销成功');
- }
- }
|