feat : coupon

This commit is contained in:
2025-03-21 16:15:28 +08:00
parent 11a36ece80
commit 8a4674b1dc
11 changed files with 190 additions and 11 deletions

View File

@@ -37,7 +37,7 @@ abstract class CateringBaseService extends BaseService
protected int $cycleId;
/**
* @var int todo 厨房id 自选的需要
* @var int
*/
protected int $kitchenId;

View File

@@ -14,8 +14,11 @@ use App\Constants\Admin\CateringCode;
use App\Constants\Common\OrderCode;
use App\Exception\ErrException;
use App\Model\Order;
use App\Model\OrderGood;
use App\Model\OrderMealCateringLog;
use App\Service\Admin\Catering\CateringBaseService;
use Exception;
use Hyperf\DbConnection\Db;
use Hyperf\Di\Annotation\Inject;
class CheckService extends CateringBaseService
@@ -38,6 +41,12 @@ class CheckService extends CateringBaseService
#[Inject]
protected Order $orderModel;
/**
* @var OrderGood
*/
#[Inject]
protected OrderGood $orderGoodModel;
/**
* @return array
*/
@@ -61,7 +70,10 @@ class CheckService extends CateringBaseService
if (empty($orderIds)) throw new ErrException('数据错误');
$this->orderModel->whereIn('id', $orderIds)->update(['status' => OrderCode::PLAN]);
// $this->orderModel->whereIn('id', $orderIds)->update(['status' => OrderCode::PLAN]);
Db::transaction(function () use ($orderIds) {
if (!$this->orderModel->isCateringByOrderIds($orderIds) || !$this->orderGoodModel->isCateringByOrderIds($orderIds)) throw new Exception('修改订单数据状态失败');
});
return $this->return->success();
}

View File

@@ -159,7 +159,7 @@ class CateringService extends CateringBaseService
$this->logInfo->status = CateringCode::CATERING_STATUS_FINISH;
if (!$this->logInfo->save()) throw new Exception('配餐失败1');
if (!$this->orderModel->isCateringByOrderIds($this->orderIds)) throw new Exception('配餐失败2');
if (!$this->orderModel->isCateringByOrderIds($this->orderIds) || !$this->orderGoodModel->isCateringByOrderIds($this->orderIds)) throw new Exception('配餐失败2');
Db::commit();
@@ -190,7 +190,7 @@ class CateringService extends CateringBaseService
$currentDate = date('Y-m-d H:i:s');
foreach ($this->orderList as &$order) {
foreach ($order['copies_list'] as &$copiesItem) {
if ($currentCode % $this->printBoxMaxNum === 0) {
if ($currentCode / $this->printBoxMaxNum === 0) {
$startCode = $currentCode + 1;
$endCode = min($currentCode + $this->printBoxMaxNum, $this->totalCopies);
$codeGroups = $this->splitArrayIntoPartitions(range($startCode, $endCode));

View File

@@ -91,7 +91,7 @@ class SkuService extends BaseService
$this->updateOssObjects(explode(',',$imageIds));
$insertModel->spu_id = $spuId;
$insertModel->title = $this->request->input('title');
$insertModel->title = $spuInfo->title.$this->request->input('title');
$insertModel->price = $this->request->input('price');
$insertModel->image_ids = $imageIds;
$insertModel->param = $this->request->input('param','');

View File

@@ -10,13 +10,145 @@ declare(strict_types=1);
namespace App\Service\Admin\Order;
use App\Cache\Redis\Api\SiteCache;
use App\Model\Order;
use App\Model\OrderGood;
use App\Model\Sku;
use App\Service\Admin\BaseService;
use Hyperf\Di\Annotation\Inject;
use Psr\Container\ContainerExceptionInterface;
use Psr\Container\NotFoundExceptionInterface;
class OrderListService extends BaseService
{
public function handle()
/**
* @var Order
*/
#[Inject]
protected Order $orderModel;
/**
* @var OrderGood
*/
#[Inject]
protected OrderGood $orderGoodModel;
/**
* @var Sku
*/
#[Inject]
protected Sku $skuModel;
/**
* @var SiteCache
*/
#[Inject]
protected SiteCache $siteCache;
/**
* @return array
* @throws ContainerExceptionInterface
* @throws NotFoundExceptionInterface
*/
public function handle(): array
{
//todo Write logic
return $this->return->success();
$limit = (int)$this->request->input('limit', 20);
//todo where
$orderList = $this->orderModel
->when($this->request->input('search_user_id'), function ($query) {
$query->where('user_id', $this->request->input('search_user_id'));
})
->when($this->request->input('search_status'), function ($query) {
$query->where('status', $this->request->input('search_status'));
})
->select([
'id',
'cycle_id',
'order_sno',
'user_id',
'site_id',
'copies',
'type',
'actual_price',
'total_price',
'status',
'create_time',
'pay_time'
])
->orderByDesc('id')
->paginate($limit)
->toArray();
if (!empty($orderList['data'])) {
$this->buildData($orderList['data']);
}
return $this->return->success('success', ['list' => $orderList]);
}
/**
* 构建订单列表数据
* @param array $orderList
* @return void
* @throws ContainerExceptionInterface
* @throws NotFoundExceptionInterface
*/
private function buildData(array &$orderList): void
{
$orderIds = array_column($orderList, 'id');
$orderSkuList = $this->orderGoodModel->whereIn('order_id', $orderIds)->get()->toArray();
$skuIds = [];
$newOrderSkuList = [];
foreach ($orderSkuList as $orderSku) {
if (empty($newOrderSkuList[$orderSku['order_id']])) {
$newOrderSkuList[$orderSku['order_id']] = [];
}
if (empty($newOrderSkuList[$orderSku['order_id']][$orderSku['copies']])) {
$newOrderSkuList[$orderSku['order_id']][$orderSku['copies']] = [];
}
$newOrderSkuList[$orderSku['order_id']][$orderSku['copies']][] = $orderSku;
if (in_array($orderSku['sku_id'], $skuIds)) continue;
$skuIds[] = $orderSku['sku_id'];
}
unset($orderSkuList);
$skuList = $this->skuModel->getDataArrByIds($skuIds);
$skuList = array_column($skuList, null,'id');
foreach ($orderList as &$order) {
$orderCopiesList = [];
for ($i = 1; $i <= ($order['copies'] ?? 0); $i++) {
$oneCopiesInfo = [
'total_price' => '0.00',
'total_quantity' => 0,
'sku_list' => [],
'take_food_code' => [], //todo 取餐码
];
foreach ($newOrderSkuList[$order['id']][$i] as $item) {
if ($item['order_id'] != $order['id'] || $item['copies'] != $i) continue;
$skuInfo = $skuList[$item['sku_id']] ?? [];
$oneCopiesInfo['total_price'] = bcadd($oneCopiesInfo['total_price'], bcmul($item['unit_price'],(string)$item['quantity'],2), 2);
$oneCopiesInfo['total_quantity'] += $item['quantity'];
$oneCopiesInfo['sku_list'][] = $skuInfo;
}
$orderCopiesList[] = $oneCopiesInfo;
}
$order['copies_list'] = $orderCopiesList;
$order['site'] = $this->siteCache->getSiteInfo((int)$order['site_id']) ?? [];
}
}
}