mirror of
https://gitee.com/zoujingli/ThinkAdmin.git
synced 2025-04-06 03:58:04 +08:00
90 lines
3.0 KiB
PHP
90 lines
3.0 KiB
PHP
<?php
|
|
|
|
namespace app\data\service;
|
|
|
|
use think\admin\Service;
|
|
|
|
/**
|
|
* 订单数据服务
|
|
* Class OrderService
|
|
* @package app\data\service
|
|
*/
|
|
class OrderService extends Service
|
|
{
|
|
/**
|
|
* 同步订单支付状态
|
|
* @param string $orderno
|
|
* @return bool
|
|
*/
|
|
public function syncAmount(string $orderno): bool
|
|
{
|
|
//@todo 处理订单支付完成的动作
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* 获取随机减免金额
|
|
* @return float
|
|
*/
|
|
public function getReduct()
|
|
{
|
|
return rand(1, 100) / 100;
|
|
}
|
|
|
|
/**
|
|
* 同步订单关联商品的库存
|
|
* @param string $order_no 订单编号
|
|
* @return bool
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
* @throws \think\db\exception\DbException
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
*/
|
|
public function syncStock(string $order_no)
|
|
{
|
|
$map = ['order_no' => $order_no];
|
|
$codes = $this->app->db->name('ShopOrderItem')->where($map)->column('goods_code');
|
|
foreach (array_unique($codes) as $code) GoodsService::instance()->syncStock($code);
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* 绑定订单详情数据
|
|
* @param array $data
|
|
* @return array
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
* @throws \think\db\exception\DbException
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
*/
|
|
public function buildItemData(array &$data = []): array
|
|
{
|
|
$nos = array_unique(array_column($data, 'order_no'));
|
|
// 关联会员数据
|
|
$mids = array_unique(array_merge(array_column($data, 'mid'), array_column($data, 'from')));
|
|
$members = $this->app->db->name('DataMember')->whereIn('id', $mids)->column('*', 'id');
|
|
foreach ($members as &$user) {
|
|
unset($user['token'], $user['tokenv'], $user['openid1'], $user['openid2']);
|
|
unset($user['unionid'], $user['password'], $user['status'], $user['deleted']);
|
|
}
|
|
// 关联发货信息
|
|
$trucks = $this->app->db->name('ShopOrderSend')->whereIn('order_no', $nos)->column('*', 'order_no');
|
|
foreach ($trucks as &$item) unset($item['id'], $item['mid'], $item['status'], $item['deleted'], $item['create_at']);
|
|
// 关联订单商品
|
|
$query = $this->app->db->name('ShopOrderItem')->where(['status' => 1, 'deleted' => 0]);
|
|
$items = $query->withoutField('id,mid,status,deleted,create_at')->whereIn('order_no', $nos)->select()->toArray();
|
|
foreach ($data as &$vo) {
|
|
$vo['sales'] = 0;
|
|
$vo['member'] = $members[$vo['mid']] ?? [];
|
|
$vo['fromer'] = $members[$vo['from']] ?? [];
|
|
$vo['truck'] = $trucks[$vo['order_no']] ?? [];
|
|
$vo['items'] = [];
|
|
foreach ($items as $item) {
|
|
if ($vo['order_no'] === $item['order_no']) {
|
|
$vo['items'][] = $item;
|
|
$vo['sales'] += $item['stock_sales'];
|
|
}
|
|
}
|
|
}
|
|
return $data;
|
|
}
|
|
|
|
} |