You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
240 lines
9.3 KiB
240 lines
9.3 KiB
3 months ago
|
<?php
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Copyright (c) 2016~2020 https://www.crmeb.com All rights reserved.
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Author: CRMEB Team <admin@crmeb.com>
|
||
|
// +----------------------------------------------------------------------
|
||
|
declare (strict_types=1);
|
||
|
|
||
|
namespace app\services\order;
|
||
|
|
||
|
|
||
|
use app\services\BaseServices;
|
||
|
use think\exception\ValidateException;
|
||
|
use app\dao\order\StoreOrderInvoiceDao;
|
||
|
use app\services\user\UserInvoiceServices;
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Class StoreOrderInvoiceServices
|
||
|
* @package app\services\order
|
||
|
* @mixin StoreOrderInvoiceDao
|
||
|
*/
|
||
|
class StoreOrderInvoiceServices extends BaseServices
|
||
|
{
|
||
|
/**
|
||
|
* LiveAnchorServices constructor.
|
||
|
* @param StoreOrderInvoiceDao $dao
|
||
|
*/
|
||
|
public function __construct(StoreOrderInvoiceDao $dao)
|
||
|
{
|
||
|
$this->dao = $dao;
|
||
|
}
|
||
|
|
||
|
public function chart(array $where)
|
||
|
{
|
||
|
//全部
|
||
|
$data['all'] = (string)$this->dao->count(['is_pay' => 1, 'is_del' => 0, 'time' => $where['time']]);
|
||
|
//待开
|
||
|
$data['noOpened'] = (string)$this->dao->count(['is_pay' => 1, 'is_del' => 0, 'time' => $where['time'], 'type' => 1]);
|
||
|
//已开
|
||
|
$data['opened'] = (string)$this->dao->count(['is_pay' => 1, 'is_del' => 0, 'time' => $where['time'], 'type' => 2]);
|
||
|
//退款
|
||
|
$data['refund'] = (string)$this->dao->count(['is_pay' => 1, 'is_del' => 0, 'time' => $where['time'], 'type' => 3]);
|
||
|
return $data;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 后台获取开票列表
|
||
|
* @param $where
|
||
|
* @return array
|
||
|
*/
|
||
|
public function getList(array $where)
|
||
|
{
|
||
|
[$page, $list] = $this->getPageValue();
|
||
|
$field = 'id as invoice_id,order_id,header_type,type,name,invoice_amount,duty_number,drawer_phone,email,tell,address,bank,card_number,is_invoice,invoice_number,remark as invoice_reamrk,invoice_time,add_time as invoice_add_time';
|
||
|
$where['is_pay'] = 1;
|
||
|
$where['is_del'] = 0;
|
||
|
$list = $this->dao->getList($where, $field, ['order' => function ($query) {
|
||
|
$query->field('id,order_id,pay_price,add_time,real_name,user_phone,status,refund_status');
|
||
|
}], 'add_time desc', $page, $list);
|
||
|
foreach ($list as &$item) {
|
||
|
$item['id'] = $item['order']['id'] ?? 0;
|
||
|
$item['order_id'] = $item['order']['order_id'] ?? '';
|
||
|
$item['pay_price'] = $item['order']['pay_price'] ?? 0.00;
|
||
|
$item['real_name'] = $item['order']['real_name'] ?? '';
|
||
|
$item['user_phone'] = $item['order']['user_phone'] ?? '';
|
||
|
$item['status'] = $item['order']['status'] ?? '';
|
||
|
$item['refund_status'] = $item['order']['refund_status'] ?? 0;
|
||
|
$item['add_time'] = date('Y-m-d H:i:s', $item['order']['add_time'] ?? $item['invoice_add_time'] ?? time());
|
||
|
$item['invoice_add_time'] = date('Y-m-d H:i:s', $item['invoice_add_time']);
|
||
|
}
|
||
|
$count = $this->dao->count($where);
|
||
|
return compact('list', 'count');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 前端获取开票列表(带商品信息)
|
||
|
* @param $where
|
||
|
* @return array
|
||
|
*/
|
||
|
public function getOrderInvoiceList(array $where)
|
||
|
{
|
||
|
[$page, $list] = $this->getPageValue();
|
||
|
$where['is_pay'] = 1;
|
||
|
$where['is_del'] = 0;
|
||
|
$where['is_refund'] = 0;
|
||
|
$list = $this->dao->getList($where, '*', ['order'], 'add_time desc', $page, $list);
|
||
|
/** @var StoreOrderServices $storeOrderServices */
|
||
|
$storeOrderServices = app()->make(StoreOrderServices::class);
|
||
|
foreach ($list as &$item) {
|
||
|
if (isset($item['order']) && $item['order']) {
|
||
|
$item['order'] = $storeOrderServices->tidyOrder($item['order'], true);
|
||
|
if (isset($item['order']['_status']['_type']) && $item['order']['_status']['_type'] == 3) {
|
||
|
foreach ($item['order']['cartInfo'] ?: [] as $key => $product) {
|
||
|
$item['order']['cartInfo'][$key]['add_time'] = isset($product['add_time']) ? date('Y-m-d H:i', (int)$product['add_time']) : '时间错误';
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
return $list;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 订单申请开票
|
||
|
* @param int $uid
|
||
|
* @param $order_id
|
||
|
* @param int $invoice_id
|
||
|
* @return mixed
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\DbException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
*/
|
||
|
public function makeUp(int $uid, $order_id, int $invoice_id)
|
||
|
{
|
||
|
/** @var StoreOrderServices $storeOrderServices */
|
||
|
$storeOrderServices = app()->make(StoreOrderServices::class);
|
||
|
/** @var UserInvoiceServices $userInvoiceServices */
|
||
|
$userInvoiceServices = app()->make(UserInvoiceServices::class);
|
||
|
$order = $storeOrderServices->getOne(['order_id|id' => $order_id, 'is_del' => 0]);
|
||
|
if (!$order) {
|
||
|
throw new ValidateException('订单不存在');
|
||
|
}
|
||
|
if ($order['pay_price'] <= 0) {
|
||
|
throw new ValidateException('订单实际支付金额为0,不能开发票');
|
||
|
}
|
||
|
//检测再带查询
|
||
|
$invoice = $userInvoiceServices->checkInvoice($invoice_id, $uid);
|
||
|
|
||
|
if ($this->dao->getOne(['order_id' => $order['id'], 'uid' => $uid])) {
|
||
|
throw new ValidateException('发票已申请,正在审核打印中');
|
||
|
}
|
||
|
if ($order['refund_status'] == 2) {
|
||
|
throw new ValidateException('订单已退款');
|
||
|
}
|
||
|
if ($order['refund_status'] == 1) {
|
||
|
throw new ValidateException('正在申请退款中');
|
||
|
}
|
||
|
unset($invoice['id'], $invoice['add_time']);
|
||
|
$data = [];
|
||
|
$data['category'] = 'order';
|
||
|
$data['order_id'] = $order['id'];
|
||
|
$data['invoice_id'] = $invoice_id;
|
||
|
$data['add_time'] = time();
|
||
|
$data['is_pay'] = $order['paid'] == 1 ? 1 : 0;
|
||
|
$data = array_merge($data, $invoice);
|
||
|
if (!$re = $this->dao->save($data)) {
|
||
|
throw new ValidateException('申请失败,请稍后重试');
|
||
|
}
|
||
|
return ['id' => $re->id];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 设置处理发票
|
||
|
* @param int $id
|
||
|
* @param array $data
|
||
|
* @return bool
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\DbException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
*/
|
||
|
public function setInvoice(int $id, array $data)
|
||
|
{
|
||
|
$orderInvoice = $this->dao->get($id);
|
||
|
if (!$orderInvoice) {
|
||
|
throw new ValidateException('数据不存在');
|
||
|
}
|
||
|
$data['invoice_time'] = time();
|
||
|
if (!$this->dao->update($id, $data, 'id')) {
|
||
|
throw new ValidateException('设置失败,请重试');
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 根据订单id获取发票信息
|
||
|
* @param int $oid
|
||
|
* @return array|\think\Model|null
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\DbException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
*/
|
||
|
public function getOneInvoice(int $oid)
|
||
|
{
|
||
|
$info = $this->dao->get(['order_id' => $oid]);
|
||
|
$info = $info ? $info->toArray() : [];
|
||
|
if (!$info) {
|
||
|
throw new ValidateException('数据不存在');
|
||
|
}
|
||
|
return $info;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 拆分订单同步拆分申请开票记录
|
||
|
* @param int $oid
|
||
|
* @return bool
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\DbException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
*/
|
||
|
public function splitOrderInvoice(int $oid)
|
||
|
{
|
||
|
/** @var StoreOrderServices $storeOrderServices */
|
||
|
$storeOrderServices = app()->make(StoreOrderServices::class);
|
||
|
$orderInfo = $storeOrderServices->getOne(['id' => $oid, 'is_del' => 0]);
|
||
|
if (!$orderInfo) {
|
||
|
throw new ValidateException('订单不存在');
|
||
|
}
|
||
|
$pid = $orderInfo['pid'] > 0 ? $orderInfo['pid'] : $orderInfo['id'];
|
||
|
//查询开票记录
|
||
|
$orderInvoice = $this->dao->get(['order_id' => $oid]);
|
||
|
//查询子订单
|
||
|
$spliteOrder = $storeOrderServices->getColumn(['pid' => $pid, 'is_system_del' => 0], 'id,order_id');
|
||
|
if ($spliteOrder && $orderInvoice) {
|
||
|
$data = $orderInvoice->toArray();
|
||
|
unset($data['id']);
|
||
|
$data['add_time'] = strtotime($data['add_time']);
|
||
|
$data_all = [];
|
||
|
foreach ($spliteOrder as $order) {
|
||
|
if (!$this->dao->count(['order_id' => $order['id']])) {
|
||
|
$data['order_id'] = $order['id'];
|
||
|
$data_all[] = $data;
|
||
|
}
|
||
|
}
|
||
|
if ($data_all) {
|
||
|
$this->transaction(function () use ($data_all, $orderInvoice, $orderInfo) {
|
||
|
$this->dao->saveAll($data_all);
|
||
|
if ($orderInfo['pid'] <= 0) {
|
||
|
$this->dao->delete(['id' => $orderInvoice['id']]);
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
}
|