diff --git a/composer.json b/composer.json
index c5ef026..6a89591 100644
--- a/composer.json
+++ b/composer.json
@@ -12,6 +12,9 @@
"email": "1163816051@qq.com"
}
],
+ "require": {
+ "overtrue/laravel-wechat": "^7.0"
+ },
"autoload": {
"psr-4": {
"Peidikeji\\Order\\": "src/"
diff --git a/database/2022_08_26_110108_create_order_ships_table.php b/database/2022_08_26_110108_create_order_ships_table.php
new file mode 100644
index 0000000..5b3f104
--- /dev/null
+++ b/database/2022_08_26_110108_create_order_ships_table.php
@@ -0,0 +1,53 @@
+id();
+ $table->unsignedBigInteger('order_id')->comment('订单ID, orders.id');
+ $table->string('sn')->nullable()->comment('发货单流水号');
+
+ $table->unsignedInteger('ship_status')->default(0);
+ $table->json('ship_data')->nullable()->comment('物流信息');
+ $table->json('ship_address')->nullable()->comment('配送地址');
+ $table->dateTime('finish_at')->nullable()->comment('收货时间');
+
+ $table->timestamps();
+
+ $table->comment('订单-发货记录');
+ });
+
+ Schema::create('order_ship_goods', function (Blueprint $table) {
+ $table->id();
+ $table->unsignedBigInteger('ship_id')->comment('发货记录ID');
+ $table->unsignedBigInteger('order_goods_id')->comment('订单商品ID');
+ $table->string('goods_name')->nullable()->comment('商品名称');
+ $table->string('cover_image')->nullable()->comment('商品图片');
+ $table->unsignedInteger('amount')->comment('发货数量');
+
+ $table->comment('订单-发货商品');
+ });
+ }
+
+ /**
+ * Reverse the migrations.
+ *
+ * @return void
+ */
+ public function down()
+ {
+ Schema::dropIfExists('order_ship_goods');
+ Schema::dropIfExists('order_ships');
+ }
+};
diff --git a/src/Action/ShowShipQrcode.php b/src/Action/ShowShipQrcode.php
deleted file mode 100644
index 930f9f4..0000000
--- a/src/Action/ShowShipQrcode.php
+++ /dev/null
@@ -1,33 +0,0 @@
-getKey();
- $order = Order::findOrFail($id);
- $url = $order->generateShipQrcode();
- if (!$url) {
- return $this->response()->error('生成提货码失败');
- }
-
- return $this->response()->success('操作成功')->refresh();
- }
-
- public function allowed()
- {
- $model = $this->parent->model();
- $code = data_get($model, 'extra.ship_qrcode');
- return $model->scene === OrderScene::Merchant && !$code;
- }
-}
diff --git a/src/Console/OrdeReceive.php b/src/Console/OrdeReceive.php
index 71c4f6c..2c5550d 100644
--- a/src/Console/OrdeReceive.php
+++ b/src/Console/OrdeReceive.php
@@ -4,11 +4,9 @@ namespace Peidikeji\Order\Console;
use Illuminate\Console\Command;
use Illuminate\Support\Facades\DB;
-use Peidikeji\Order\Enums\PayStatus;
use Peidikeji\Order\Enums\ShipStatus;
use Peidikeji\Order\Models\Order;
use Peidikeji\Order\OrderService;
-use Peidikeji\Setting\Models\Setting;
class OrdeReceive extends Command
{
@@ -27,10 +25,9 @@ class OrdeReceive extends Command
if ($id) {
$this->receive(Order::findOrFail($id));
} else {
- $day = Setting::where('slug', 'order_receive_day')->value('value');
$query = Order::where('ship_status', ShipStatus::Finished)
->where('is_closed', 0)
- ->where('ship_at', '<', now()->subDays($day));
+ ->where('ship_at', '<', now()->subDays(7));
$list = $query->get();
foreach($list as $item) {
$this->receive($item);
diff --git a/src/Console/OrderCancel.php b/src/Console/OrderCancel.php
index 17d9f5d..eb3c1ce 100644
--- a/src/Console/OrderCancel.php
+++ b/src/Console/OrderCancel.php
@@ -26,8 +26,7 @@ class OrderCancel extends Command
if ($id) {
$this->cancel(Order::findOrFail($id));
} else {
- $hour = Setting::where('slug', 'order_cancel_hour')->value('value');
- $query = Order::where('pay_status', PayStatus::None)->where('is_closed', 0)->where('created_at', '<', now()->subHours($hour));
+ $query = Order::where('pay_status', PayStatus::None)->where('is_closed', 0)->where('created_at', '<', now()->subMinutes(15));
$list = $query->get();
foreach($list as $item) {
$this->cancel($item);
diff --git a/src/Enums/OrderScene.php b/src/Enums/OrderScene.php
deleted file mode 100644
index 91087c0..0000000
--- a/src/Enums/OrderScene.php
+++ /dev/null
@@ -1,51 +0,0 @@
-value => '线上商城',
- self::Merchant->value => '线下门店',
- self::Scan->value => '扫码付款',
- ];
- }
-
- public function text()
- {
- return data_get(self::options(), $this->value);
- }
-
- public function color()
- {
- return match ($this) {
- static::Online => 'primary',
- static::Merchant => 'warning',
- static::Scan => 'success',
- };
- }
-
- public function label()
- {
- $color = $this->color();
-
- $name = $this->text();
-
- return "{$name}";
- }
-
- public function dot()
- {
- $color = $this->color();
-
- $name = $this->text();
-
- return " {$name}";
- }
-}
diff --git a/src/Enums/OrderStatus.php b/src/Enums/OrderStatus.php
index 86cd425..c70b15c 100644
--- a/src/Enums/OrderStatus.php
+++ b/src/Enums/OrderStatus.php
@@ -25,7 +25,7 @@ enum OrderStatus: int
self::Send->value => '已发货(部分)',
// 全部发货
self::SendFull->value => '已发货',
- self::Receive->value => '已完成',
+ self::Receive->value => '已收货',
// 已评价
self::Review->value => '已评价',
@@ -55,9 +55,9 @@ enum OrderStatus: int
self::Paying => 'secondary',
self::Paid => 'success',
self::Send => 'primary',
- self::SendFull => 'primary',
- self::Receive => 'primary',
- self::Review => 'success',
+ self::SendFull => 'danger',
+ self::Receive => 'success',
+ self::Review => 'primary',
self::PayFail => 'danger',
self::Cancel => 'secondary',
default => 'dark'
diff --git a/src/Enums/PayStatus.php b/src/Enums/PayStatus.php
index 8fc3143..c6d7dd6 100644
--- a/src/Enums/PayStatus.php
+++ b/src/Enums/PayStatus.php
@@ -38,7 +38,7 @@ enum PayStatus: int
public function color()
{
return match ($this) {
- static::None => 'secondary',
+ static::None => 'dark',
static::Processing => 'primary',
self::Success => 'success',
self::Fail => 'danger',
diff --git a/src/Exceptions/OrderException.php b/src/Exceptions/OrderException.php
index fea5ff1..a70f670 100644
--- a/src/Exceptions/OrderException.php
+++ b/src/Exceptions/OrderException.php
@@ -2,12 +2,22 @@
namespace Peidikeji\Order\Exceptions;
-use App\Exceptions\BizException;
+use Dcat\Admin\Traits\JsonResponse;
+use Exception;
-class OrderException extends BizException
+class OrderException extends Exception
{
- public function __construct(string $message, int $code = 400)
+ use JsonResponse;
+
+ protected $code = 400;
+
+ public function report()
{
- parent::__construct($message, $code);
+ return false;
+ }
+
+ public function render($request)
+ {
+ return $this->error($this->message, $this->code);
}
}
diff --git a/src/Form/PayForm.php b/src/Form/PayForm.php
index 615d979..72383c6 100644
--- a/src/Form/PayForm.php
+++ b/src/Form/PayForm.php
@@ -28,7 +28,7 @@ class PayForm extends Form implements LazyRenderable
$order = Order::findOrFail($id);
// 验证积分余额是否足够
if ($order->score_discount_amount > 0 && $order->user) {
- if ($order->user->profit < $order->score_discount_amount) {
+ if ($order->user->balance < $order->score_discount_amount) {
throw new OrderException('用户积分余额不足');
}
}
diff --git a/src/Form/ShipForm.php b/src/Form/ShipForm.php
index a8cb77a..af3710a 100644
--- a/src/Form/ShipForm.php
+++ b/src/Form/ShipForm.php
@@ -31,9 +31,10 @@ class ShipForm extends Form implements LazyRenderable
}
DB::beginTransaction();
$order = Order::findOrFail($this->payload['id']);
- $code = $input['company_code'];
- $company = data_get(array_flip(Kuaidi100Service::$codeArr), $code, '未知');
- $sn = $input['sn'];
+
+ $code = data_get($input, 'company_code');
+ $company = data_get($input, 'company');
+ $sn = data_get($input, 'sn');
OrderService::make()->ship($order, $input['goods'], compact('code', 'company', 'sn'));
$admin = Admin::user();
@@ -69,12 +70,9 @@ class ShipForm extends Form implements LazyRenderable
}
$this->fill(['goods' => $goods]);
- $way = $this->payload['ship_way'];
-
- if ($way === ShipWay::Express->value) {
- $this->select('company_code', '快递公司')->options(array_flip(Kuaidi100Service::$codeArr));
- $this->text('sn', '快递单号')->required();
- }
+ $this->text('company', '快递公司');
+ $this->text('company_code', '快递公司编码');
+ $this->text('sn', '快递单号');
$this->table('goods', '', function (NestedForm $table) {
$spec = data_get($table->model(), 'goods.spec');
$table->hidden('order_goods_id');
@@ -97,9 +95,7 @@ class ShipForm extends Form implements LazyRenderable
}
$table->display('total_amount', '总数量');
$table->display('ship_amount', '已发');
- $table->number('amount', '数量')->default(1)->min(1)->options(['upClass' => null, 'downClass' => null]);
- })->horizontal(false)->setFieldClass('col-12')->options([
- 'allowCreate' => false,
- ])->required();
+ $table->number('amount', '数量')->default(1)->min(0)->prepend('')->append('');
+ })->horizontal(false)->setFieldClass('col-12')->options(['allowCreate' => false])->required();
}
}
diff --git a/src/Http/Admin/OrderController.php b/src/Http/Admin/OrderController.php
index 822f80c..9287e42 100644
--- a/src/Http/Admin/OrderController.php
+++ b/src/Http/Admin/OrderController.php
@@ -15,7 +15,6 @@ use Dcat\Admin\Show;
use Dcat\Admin\Show\Tools;
use Dcat\Admin\Widgets\Box;
use Illuminate\Support\Arr;
-use Peidikeji\Merchant\Models\Merchant;
use Peidikeji\Order\Action\ShowCancel;
use Peidikeji\Order\Action\ShowDelete;
use Peidikeji\Order\Action\ShowPay;
@@ -23,7 +22,6 @@ use Peidikeji\Order\Action\ShowPayQuery;
use Peidikeji\Order\Action\ShowReceive;
use Peidikeji\Order\Action\ShowRemarks;
use Peidikeji\Order\Action\ShowShip;
-use Peidikeji\Order\Action\ShowShipQrcode;
use Peidikeji\Order\Enums\OrderStatus;
use Peidikeji\Order\Enums\PayStatus;
use Peidikeji\Order\Models\Order;
@@ -39,13 +37,13 @@ class OrderController extends AdminController
protected function grid()
{
- return Grid::make(Order::with(['user', 'merchant']), function (Grid $grid) {
+ return Grid::make(Order::with(['user']), function (Grid $grid) {
+ $grid->disableRowSelector();
$grid->model()->sort();
$grid->filter(function (Filter $filter) {
$filter->panel();
$filter->like('sn')->width(4);
- $filter->equal('merchant_id')->select()->ajax('api/merchants?_paginate=1')->model(Merchant::class, 'id', 'name')->width(4);
$filter->equal('user_id')->select()->ajax('api/user?_paginate=1')->model(User::class, 'id', 'phone')->width(4);
$filter->where('order_status', fn($q) => $q->filter(['status' => $this->input]))->select(OrderStatus::options())->width(4);
$filter->whereBetween('created_at', function ($q) {
@@ -64,8 +62,7 @@ class OrderController extends AdminController
})->date()->width(4);
});
- $grid->column('scene')->display(fn() => $this->scene->label());
- $grid->column('sn')->link(fn() => admin_url('orders', ['id' => $this->id]));
+ $grid->column('sn')->copyable();
$grid->column('merchant.name');
$grid->column('user.phone');
$grid->column('total_money');
@@ -75,19 +72,22 @@ class OrderController extends AdminController
$user = Admin::user();
$grid->showViewButton($user->can('dcat.admin.orders.show'));
+ $grid->disableCreateButton();
+ $grid->disableEditButton();
+ $grid->disableDeleteButton();
});
}
protected function detail($id)
{
- $info = Order::with(['user', 'merchant'])->findOrFail($id);
+ $info = Order::with(['user'])->findOrFail($id);
$row = new Row();
$row->column(6, Show::make($info, function (Show $show) {
+ $show->disableEditButton();
+ $show->disableDeleteButton();
$info = $show->model();
$show->row(function (Show\Row $show) {
- $show->width(6)->field('scene')->as(fn() => $this->scene->label())->unescape();
$show->width(6)->field('user.phone');
- $show->width(6)->field('merchant.name');
$show->width(6)->field('sn');
$show->width(6)->field('status', '状态')->as(fn() => $this->status()->label())->unescape();
$show->width(6)->field('created_at');
@@ -99,27 +99,25 @@ class OrderController extends AdminController
$show->row(function (Show\Row $show) {
$show->width(6)->field('score_discount_money');
$show->width(6)->field('score_discount_amount');
- $show->width(6)->field('score_discount_ratio');
- $show->width(6)->field('vip_discount_money');
+ // $show->width(6)->field('score_discount_ratio');
});
$show->row(function (Show\Row $show) use ($info) {
- $show->width(6)->field('pay_money');
- $show->width(6)->field('pay_status')->as(fn() => $this->pay_status->label())->unescape();
+ // $show->width(6)->field('pay_status')->as(fn() => $this->pay_status->label())->unescape();
$show->width(6)->field('pay_way')->as(fn() => $this->pay_way?->label())->unescape();
+ $show->width(6)->field('pay_money');
if ($info->pay_status === PayStatus::Success) {
$show->width(6)->field('pay_at');
$show->width(6)->field('pay_no');
}
});
$show->row(function (Show\Row $show) use ($info) {
- $show->width(6)->field('ship_status')->as(fn() => $this->ship_status->label())->unescape();
- $show->width(6)->field('ship_money');
+ // $show->width(6)->field('ship_status')->as(fn() => $this->ship_status->label())->unescape();
$show->width(6)->field('ship_address')->as(fn($v) => $v ? implode(',', Arr::only($v, ['name', 'phone', 'address'])) : '');
+ $show->width(6)->field('ship_money');
$show->width(6)->field('ship_way')->as(fn() => $this->ship_way?->label())->unescape();
$show->width(6)->field('ship_at');
});
$show->row(function (Show\Row $show) use ($info) {
- $show->width(6)->field('user_get_profit');
$show->width(6)->field('remarks');
});
$show->tools(function (Tools $tools) {
@@ -128,14 +126,15 @@ class OrderController extends AdminController
$tools->append(new ShowPayQuery());
$tools->append(new ShowShip());
$tools->append(new ShowReceive());
- $tools->append(new ShowShipQrcode());
$tools->append(new ShowDelete());
$tools->append(new ShowRemarks());
});
}));
$row->column(6, function (Column $column) use ($info) {
- $goodsGrid = Grid::make(OrderGoods::where('order_id', $info->id), function (Grid $grid) {
+ $column->row(Box::make('订单商品', Grid::make(OrderGoods::where('order_id', $info->id), function (Grid $grid) {
+ $grid->disableRowSelector();
+ $grid->disableCreateButton();
$grid->disablePagination();
$grid->disableActions();
$grid->disableRefreshButton();
@@ -145,9 +144,10 @@ class OrderController extends AdminController
$grid->column('ship_amount', '已发');
$grid->column('spec', '规格')->display(fn($v) => $v ? array_column($v, 'value') : '')->label();
$grid->column('money', '合计');
- });
- $column->row(Box::make('订单商品', $goodsGrid));
+ })));
$column->row(Box::make('发货单', Grid::make(OrderShip::with(['goods'])->where('order_id', $info->id)->sort(), function (Grid $grid) {
+ $grid->disableRowSelector();
+ $grid->disableCreateButton();
$grid->disablePagination();
$grid->disableActions();
$grid->disableRefreshButton();
@@ -176,6 +176,8 @@ class OrderController extends AdminController
})));
$column->row(Box::make('操作记录', Grid::make(OrderOption::with(['user'])->where('order_id', $info->id)->orderBy('created_at', 'desc'), function (Grid $grid) {
+ $grid->disableRowSelector();
+ $grid->disableCreateButton();
$grid->disablePagination();
$grid->disableActions();
$grid->disableRefreshButton();
diff --git a/src/Http/Api/OrderController.php b/src/Http/Api/OrderController.php
index 20f8651..94e00b2 100644
--- a/src/Http/Api/OrderController.php
+++ b/src/Http/Api/OrderController.php
@@ -2,18 +2,13 @@
namespace Peidikeji\Order\Http\Api;
-use Peidikeji\Order\Exceptions\OrderException;
use App\Http\Controllers\Controller;
-use App\Http\Resources\UserAddressResource;
-use App\Models\UserAddress;
-use App\Models\Zone;
-use App\Services\Kuaidi100Service;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use Illuminate\Validation\Rule;
use Illuminate\Validation\Rules\Enum;
-use Peidikeji\Merchant\Models\Merchant;
-use Peidikeji\Order\Enums\OrderScene;
+use Peidikeji\Coupon\Http\Resources\UserCouponResource;
+use Peidikeji\Coupon\Models\UserCoupon;
use Peidikeji\Order\Enums\OrderStatus;
use Peidikeji\Order\Enums\PayWay;
use Peidikeji\Order\Enums\ShipWay;
@@ -28,7 +23,7 @@ class OrderController extends Controller
{
$user = auth('api')->user();
- $query = $user->orders()->with(['goods', 'merchant'])->filter($request->all());
+ $query = $user->orders()->with(['goods'])->filter($request->all());
$list = $query->sort()->paginate($request->input('per_page'));
@@ -59,22 +54,14 @@ class OrderController extends Controller
public function sure(Request $request)
{
$request->validate([
- 'scene' => ['required', new Enum(OrderScene::class)],
'goods' => [Rule::requiredIf(!$request->filled('cart_id')), 'array'],
'cart_id' => ['array'],
- 'merchant_id' => [Rule::requiredIf($request->input('scene') === OrderScene::Merchant->value)],
+ 'address' => [Rule::requiredIf(!$request->filled('address_id')), 'array'],
+ 'address_id' => ['numeric']
]);
$user = auth('api')->user();
- $service = OrderStore::init()->user($user)->scene($request->input('scene'));
-
- if ($request->filled('merchant_id')) {
- $merchant = Merchant::findOrFail($request->input('merchant_id'));
- if (!$merchant->enable()) {
- throw new OrderException('店铺不可用');
- }
- $service->merchant($merchant);
- }
+ $service = OrderStore::init()->user($user);
$goods = $request->input('goods');
if ($request->filled('cart_id')) {
@@ -83,6 +70,61 @@ class OrderController extends Controller
$service->goods($goods);
// 收货地址
+ $address = $request->input('address');
+
+ // 优惠券
+ // $coupons = UserCoupon::where('user_id', $user->id)->effective()->get();
+
+ $service->ship(ShipWay::Express->value, $this->formatAddress($address));
+
+ $score = $request->input('score');
+ $userScore = $user->balance;
+ $maxScore = $userScore;
+ if ($score) {
+ $service->score($score);
+ }
+
+ $goodsList = $service->orderGoodsList;
+
+ // 付款金额
+ $payMoney = $service->getPayMoney();
+
+ return $this->json([
+ 'address' => $address,
+ 'list' => $goodsList,
+ 'score' => [
+ 'has' => floatval($userScore),
+ 'use' => floatval($score),
+ 'max' => floatval($maxScore)
+ ],
+ 'price' => [
+ 'goods' => floatval($goodsList->sum('money')),
+ 'ship' => $service->ship['money'],
+ 'coupon' => 0,
+ 'score' => $service->score['money'],
+ 'total' => $payMoney,
+ ],
+ 'coupons' => []
+ ]);
+ }
+
+ public function store(Request $request)
+ {
+ $user = auth('api')->user();
+
+ $store = OrderStore::init()->user($user)->remarks($request->input('remarks'));
+ $request->validate([
+ 'goods' => [Rule::requiredIf(!$request->filled('cart_id')), 'array'],
+ 'cart_id' => ['array'],
+ 'address' => [Rule::requiredIf(!$request->filled('address_id')), 'array'],
+ ]);
+
+ $goods = $request->input('goods');
+ if ($request->filled('cart_id')) {
+ $goods = $this->formatCartGoods($user->carts()->whereIn('id', $request->input('cart_id'))->get());
+ }
+ $store->goods($goods);
+
$address = null;
if ($request->filled('address_id')) {
$address = $user->addresses()->find($request->input('address_id'));
@@ -91,141 +133,13 @@ class OrderController extends Controller
}
}
if (!$address) {
- $address = $user->addresses()->orderBy('is_default', 'desc')->orderBy('created_at', 'desc')->first();
+ $address = $request->input('address');
}
- $service->ship(ShipWay::Express->value, $this->formatAddress($address));
-
- // 计算最大积分抵扣
- $maxScore = floatval($service->orderGoodsList->sum('score_max_amount'));
- $score = $request->input('score');
- $userScore = floatval($user->profit);
- if (!$score) {
- $score = $userScore > $maxScore ? $maxScore : $userScore;
- }
- $service->score($score);
+ $store->ship($request->input('ship_way', ShipWay::None->value), $this->formatAddress($address));
- $goodsList = $service->orderGoodsList;
-
- $dataList = collect();
-
- foreach($goodsList->groupBy('merchant_id') as $id => $list) {
-
- $dataList->push([
- 'merchant' => $id ? Merchant::select('id', 'name')->find($id) : ['id' => null, 'name' => '自营店铺'],
- 'list' => $list
- ]);
- }
-
- // 付款金额
- $payMoney = $service->getPayMoney();
-
- return $this->json([
- 'address' => $address ? UserAddressResource::make($address) : null,
- 'list' => $dataList,
- 'score' => [
- 'has' => $userScore,
- 'use' => $score,
- 'max' => $maxScore,
- 'bonus' => $service->getUserBonus($payMoney),
- ],
- 'price' => [
- 'goods' => floatval($goodsList->sum('price')),
- 'ship' => $service->ship['money'],
- 'coupon' => 0,
- 'vip' => $service->vip['money'],
- 'score' => $service->score['money'],
- 'total' => $payMoney,
- ]
- ]);
- }
-
- public function store(Request $request)
- {
- $user = auth('api')->user();
-
- $request->validate([
- 'scene' => ['required', new Enum(OrderScene::class)]
- ]);
-
- $scene = $request->input('scene');
- $store = OrderStore::init()->scene($scene)->user($user)->remarks($request->input('remarks'));
- // 自营商城下单
- if ($scene === OrderScene::Online->value) {
- $request->validate([
- 'goods' => [Rule::requiredIf(!$request->filled('cart_id')), 'array'],
- 'cart_id' => ['array'],
- 'address' => [Rule::requiredIf(!$request->filled('address_id')), 'array'],
- ]);
-
- $goods = $request->input('goods');
- if ($request->filled('cart_id')) {
- $goods = $this->formatCartGoods($user->carts()->whereIn('id', $request->input('cart_id'))->get());
- }
- $store->goods($goods);
-
- $address = null;
- if ($request->filled('address_id')) {
- $address = $user->addresses()->find($request->input('address_id'));
- if (!$address) {
- return $this->error('收货地址不存在');
- }
- }
- if (!$address) {
- $address = $request->input('address');
- }
-
- $store->ship(ShipWay::Express->value, $this->formatAddress($address));
-
- $store->score($request->input('score', 0));
- }
- // 店铺下单
- else if ($scene === OrderScene::Merchant->value) {
- $request->validate([
- 'goods' => [Rule::requiredIf(!$request->filled('cart_id')), 'array'],
- 'cart_id' => ['array'],
- 'merchant_id' => 'required',
- ]);
-
- $merchant = Merchant::findOrFail($request->input('merchant_id'));
- if (!$merchant->enable()) {
- throw new OrderException('店铺不可用');
- }
- $store->merchant($merchant);
-
- $goods = $request->input('goods');
- if ($request->filled('cart_id')) {
- $goods = $this->formatCartGoods($user->carts()->whereIn('id', $request->input('cart_id'))->get());
- }
- $store->goods($goods);
-
- $store->ship(ShipWay::Pick->value);
-
- // 验证店铺返现余额是否足够
- $payMoney = $store->getPayMoney();
- $ratio = $merchant->profit_ratio / 100;
- $userProfit = round($payMoney * $ratio, 2, PHP_ROUND_HALF_DOWN);
- $merchantUser = $merchant->user;
- if ($merchantUser->profit < $userProfit) {
- throw new OrderException('店铺返现账户余额不足');
- }
- }
- // 扫码付款
- else if ($scene === OrderScene::Scan->value) {
- $request->validate([
- 'money' => 'required',
- 'merchant_id' => 'required',
- ]);
-
- $merchant = Merchant::findOrFail($request->input('merchant_id'));
- if (!$merchant->enable()) {
- throw new OrderException('店铺不可用');
- }
- $store->merchant($merchant);
- $store->money($request->input('money'));
- } else {
- return $this->error('未知下单场景');
- }
+ $store->score($request->input('score', 0));
+
try {
DB::beginTransaction();
$order = $store->create();
@@ -350,20 +264,6 @@ class OrderController extends Controller
return $this->json(OrderShipResouce::collection($list));
}
- public function logistics(Request $request)
- {
- $request->validate([
- 'order_id' => 'required',
- 'ship_id' => 'required',
- ]);
-
- $user = auth('api')->user();
- $order = $user->orders()->findOrFail($request->input('order_id'));
- $ship = $order->ships()->findOrFail($request->input('ship_id'));
-
- return $this->success();
- }
-
protected function formatCartGoods($carts)
{
$goods = [];
@@ -381,27 +281,6 @@ class OrderController extends Controller
protected function formatAddress($userAddress)
{
- $address = [];
- if ($userAddress instanceof UserAddress) {
- $address = [
- 'name' => $userAddress->contact_name,
- 'phone' => $userAddress->phone,
- 'region' => [$userAddress->province?->name, $userAddress->city?->name, $userAddress->area?->name],
- 'zone' => [$userAddress->province_id, $userAddress->city_id, $userAddress->area_id],
- 'address' => $userAddress->address,
- 'address_id' => $userAddress->id
- ];
- } else if (is_array($userAddress)) {
- $address = $userAddress;
- $region = data_get($address, 'region');
- if (!$region || count($region) === 0) {
- throw new OrderException('收货地址格式不正确');
- }
- $area = Zone::where('name', $region[2])->where('type', 'area')->firstOrFail();
- $city = Zone::findOrFail($area->parent_id);
- $address['zone'] = [$city->parent_id, $area->parent_id, $area->id];
- }
-
- return $address;
+ return $userAddress;
}
}
diff --git a/src/Http/Resources/OrderResource.php b/src/Http/Resources/OrderResource.php
index 255713f..26cb170 100644
--- a/src/Http/Resources/OrderResource.php
+++ b/src/Http/Resources/OrderResource.php
@@ -3,8 +3,6 @@
namespace Peidikeji\Order\Http\Resources;
use Illuminate\Http\Resources\Json\JsonResource;
-use Peidikeji\Merchant\Http\Resources\MerchantTinyResource;
-use Peidikeji\Order\Enums\OrderScene;
class OrderResource extends JsonResource
{
@@ -14,15 +12,8 @@ class OrderResource extends JsonResource
return [
'id' => $this->id,
'sn' => $this->sn,
-
- 'scene' => $this->scene,
- 'scene_text' => $this->scene->text(),
-
'user_id' => $this->user_id,
- 'merchant_id' => $this->merchant_id,
- 'merchant' => $this->merchant_id ? MerchantTinyResource::make($this->whenLoaded('merchant')) : ['id' => '', 'name' => '自营商城'],
-
'total_money' => floatval($this->total_money),
'status' => $status,
'status_text' => $status->text(),
@@ -33,8 +24,6 @@ class OrderResource extends JsonResource
'pay_no' => $this->pay_no,
'pay_way' => $this->pay_way,
- 'vip_discount_money' => $this->vip_discount_money,
-
'score_discount_amount' => floatval($this->score_discount_amount),
'score_discount_money' => floatval($this->score_discount_money),
'score_discount_ratio' => floatval($this->score_discount_ratio),
@@ -48,11 +37,8 @@ class OrderResource extends JsonResource
'user_remarks' => $this->user_remarks,
'created_at' => $this->created_at->timestamp,
- 'user_get_profit' => floatval($this->user_get_profit),
'goods' => OrderGoodsResource::collection($this->whenLoaded('goods')),
-
- 'ship_qrcode' => data_get($this->extra, 'ship_qrcode'),
];
}
}
diff --git a/src/Listeners/OrderDiscountProfit.php b/src/Listeners/OrderDiscountProfit.php
deleted file mode 100644
index 275d407..0000000
--- a/src/Listeners/OrderDiscountProfit.php
+++ /dev/null
@@ -1,49 +0,0 @@
- 扣除用户的积分
- * 订单已退款 => 返还用户扣除的积分
- */
-class OrderDiscountProfit implements ShouldQueue
-{
- public function handle($event)
- {
- $order = $event->order;
- $user = $order->user;
- $amount = floatval($order->score_discount_amount);
- if ($amount > 0 && $user) {
- if ($order->pay_status === PayStatus::Success) {
- $user->decrement('profit', $amount);
- $user->balanceLogs()->create([
- 'type' => BalanceLog::TYPE_PROFIT,
- 'cate' => BalanceLog::CATE_PROFIT_ORDER_OUT,
- 'amount' => 0 - $amount,
- 'balance' => $user->profit,
- 'description' => '使用 '.$amount.' 积分抵扣 '.floatval($order->score_discount_money).' 元',
- 'source_id' => $order->id,
- 'source_type' => Order::class,
- ]);
- }
- else if ($order->pay_status === PayStatus::Refund) {
- $user->increment('profit', $amount);
- $user->balanceLogs()->create([
- 'type' => BalanceLog::TYPE_PROFIT,
- 'cate' => BalanceLog::CATE_PROFIT_ORDER_OUT,
- 'amount' => $amount,
- 'balance' => $user->profit,
- 'description' => '订单退款, 返还 '.$amount.' 积分',
- 'source_id' => $order->id,
- 'source_type' => Order::class,
- ]);
- }
- }
- }
-}
diff --git a/src/Listeners/OrderInviteProfit.php b/src/Listeners/OrderInviteProfit.php
deleted file mode 100644
index a3a56ba..0000000
--- a/src/Listeners/OrderInviteProfit.php
+++ /dev/null
@@ -1,51 +0,0 @@
-order;
- $user = $order->user;
- if ($order->scene === OrderScene::Online && $user && $user->inviter_path) {
- // -, -1-, -1-2-, -3-16-21-41-54-64-
- $parentIds = array_reverse(explode('-', $user->inviter_path));
- $ratio = Setting::where('slug', 'invite_profit_ratio')->value('value');
- if (count($parentIds) > 2 && $ratio > 0) {
- $amount = round($order->total_money * $ratio / 100, 2, PHP_ROUND_HALF_DOWN);
- foreach(Arr::only($parentIds, [1, 2]) as $id) {
- $this->giveUser($id, $order, $amount);
- }
- }
- }
- }
-
- protected function giveUser($id, $order, $money = 0)
- {
- $user = User::find($id);
- if ($user && $money > 0) {
- $user->increment('balance', $money);
- $user->balanceLogs()->create([
- 'type' => BalanceLog::TYPE_BALANCE,
- 'amount' => $money,
- 'balance' => $user->balance,
- 'cate' => BalanceLog::CATE_BALANCE_ORDER_PROFIT,
- 'description' => '邀请用户 '.$order->user->getSubPhone().' 下单得到返利 ' . $money,
- 'source_id' => $order->id,
- 'source_type' => Order::class,
- ]);
- }
- }
-}
diff --git a/src/Listeners/OrderMakeShipQrcode.php b/src/Listeners/OrderMakeShipQrcode.php
deleted file mode 100644
index 085a6cf..0000000
--- a/src/Listeners/OrderMakeShipQrcode.php
+++ /dev/null
@@ -1,21 +0,0 @@
-order;
- if ($order->scene === OrderScene::Merchant && $order->ship_way === ShipWay::Pick) {
- $order->generateShipQrcode();
- }
- }
-}
diff --git a/src/Listeners/OrderSendProfit.php b/src/Listeners/OrderSendProfit.php
deleted file mode 100644
index 257c172..0000000
--- a/src/Listeners/OrderSendProfit.php
+++ /dev/null
@@ -1,76 +0,0 @@
- 增加用户积分, 扣除商户积分
- * 订单已退款 => 积分原路返还
- */
-class OrderSendProfit implements ShouldQueue
-{
- public function handle($event)
- {
- $order = $event->order;
- $user = $order->user;
- $merchant = $order->merchant;
- if ($order->scene === OrderScene::Merchant && $merchant) {
- $merchantUser = $merchant->user;
- $amount = floatval($order->user_get_profit);
- if ($amount > 0 && $user && $merchantUser) {
- if ($order->pay_status === PayStatus::Success) {
- $user->increment('profit', $amount);
- $user->balanceLogs()->create([
- 'type' => BalanceLog::TYPE_PROFIT,
- 'cate' => BalanceLog::CATE_PROFIT_ORDER_IN,
- 'amount' => $amount,
- 'balance' => $user->profit,
- 'description' => '在商户 ' . $merchant->name.' 下单, 赠送 '.$amount.' 积分',
- 'source_id' => $order->id,
- 'source_type' => Order::class,
- ]);
-
- $merchantUser->decrement('profit', $amount);
- $merchantUser->balanceLogs()->create([
- 'type' => BalanceLog::TYPE_PROFIT,
- 'cate' => BalanceLog::CATE_PROFIT_ORDER_USE,
- 'amount' => 0 - $amount,
- 'balance' => $merchantUser->profit,
- 'description' => '用户 ' . $user->getSubPhone() . ' 下单送出 '.$amount.' 积分',
- 'source_id' => $order->id,
- 'source_type' => Order::class,
- ]);
- }
- else if ($order->pay_status === PayStatus::Refund) {
- $user->decrement('profit', $amount);
- $user->balanceLogs()->create([
- 'type' => BalanceLog::TYPE_PROFIT,
- 'cate' => BalanceLog::CATE_PROFIT_ORDER_IN,
- 'amount' => 0 - $amount,
- 'balance' => $user->profit,
- 'description' => '订单退款, 扣除赠送的 '.$amount.' 积分',
- 'source_id' => $order->id,
- 'source_type' => Order::class,
- ]);
-
- $merchantUser->increment('profit', $amount);
- $merchantUser->balanceLogs()->create([
- 'type' => BalanceLog::TYPE_PROFIT,
- 'cate' => BalanceLog::CATE_PROFIT_ORDER_USE,
- 'amount' => $amount,
- 'balance' => $merchantUser->profit,
- 'description' => '用户 ' . $user->getSubPhone() . ' 订单退款返还 '.$amount.' 积分',
- 'source_id' => $order->id,
- 'source_type' => Order::class,
- ]);
- }
- }
- }
- }
-}
diff --git a/src/Listeners/UpdateGoodsSoldCount.php b/src/Listeners/UpdateGoodsSoldCount.php
index e94080e..355f29d 100644
--- a/src/Listeners/UpdateGoodsSoldCount.php
+++ b/src/Listeners/UpdateGoodsSoldCount.php
@@ -4,7 +4,6 @@ namespace Peidikeji\Order\Listeners;
use Illuminate\Contracts\Queue\ShouldQueue;
use Peidikeji\Goods\Models\Goods;
-use Peidikeji\Merchant\Models\Merchant;
/**
* 更新商品销量
@@ -18,26 +17,12 @@ class UpdateGoodsSoldCount implements ShouldQueue
// true = 返还商品销量
// false = 扣除商品销量
$close = $order->is_closed;
- $merchants = [];
foreach($order->goods as $item) {
if ($close) {
Goods::where('id', $item->goods_id)->decrement('sold_count', $item->amount);
} else {
Goods::where('id', $item->goods_id)->increment('sold_count', $item->amount);
}
- if ($item->merchant_id) {
- $amount = data_get($merchants, $item->merchant_id, 0) + $item->amount;
- $merchants[$item->merchant_id] = $amount;
- }
- }
-
- // 增加店铺销量
- foreach($merchants as $id => $amount) {
- if ($close) {
- Merchant::where('id', $id)->decrement('sold_count', $amount);
- } else {
- Merchant::where('id', $id)->increment('sold_count', $amount);
- }
}
}
}
diff --git a/src/Models/Order.php b/src/Models/Order.php
index effc670..db9d2b3 100644
--- a/src/Models/Order.php
+++ b/src/Models/Order.php
@@ -6,7 +6,6 @@ use Dcat\Admin\Traits\HasDateTimeFormatter;
use EloquentFilter\Filterable;
use Illuminate\Database\Eloquent\Model;
use Peidikeji\Order\Enums\RefundStatus;
-use Peidikeji\Order\Enums\OrderScene;
use Peidikeji\Order\Enums\OrderStatus;
use Peidikeji\Order\Enums\PayStatus;
use Peidikeji\Order\Enums\PayWay;
@@ -22,13 +21,11 @@ class Order extends Model
use Filterable;
protected $fillable = [
- 'user_id',
- 'total_money', 'sn',
- 'pay_at', 'pay_money', 'pay_no', 'pay_status', 'pay_way',
+ 'sn', 'total_money', 'user_id',
+ 'ship_address', 'ship_at', 'ship_money', 'ship_status', 'ship_way', 'receive_at',
'score_discount_amount', 'score_discount_money', 'score_discount_ratio',
- 'ship_way', 'ship_address', 'ship_at', 'ship_status', 'ship_money',
- 'refund_status', 'is_closed', 'auto_close_at', 'review_at', 'receive_at',
- 'extra', 'user_remarks', 'remarks', 'scene', 'user_get_profit',
+ 'pay_at', 'pay_money', 'pay_no', 'pay_status', 'pay_way',
+ 'auto_close_at', 'extra', 'is_closed', 'refund_status', 'remarks', 'review_at', 'user_remarks'
];
protected $casts = [
@@ -37,7 +34,6 @@ class Order extends Model
'pay_status' => PayStatus::class,
'pay_way' => PayWay::class,
'ship_status' => ShipStatus::class,
- 'scene' => OrderScene::class,
'ship_way' => ShipWay::class,
'refund_status' => RefundStatus::class,
];
@@ -49,7 +45,7 @@ class Order extends Model
'refund_status' => RefundStatus::None
];
- protected $dates = ['pay_at', 'ship_at', 'receive_at'];
+ protected $dates = ['pay_at', 'ship_at', 'receive_at', 'auto_close_at'];
public function user()
{
@@ -89,6 +85,7 @@ class Order extends Model
if ($this->ship_status === ShipStatus::Processing) {
return OrderStatus::Send;
}
+
if ($this->ship_status === ShipStatus::Finished) {
return OrderStatus::SendFull;
}
diff --git a/src/OrderService.php b/src/OrderService.php
index 8fe60d5..ba3b5c1 100644
--- a/src/OrderService.php
+++ b/src/OrderService.php
@@ -64,9 +64,9 @@ class OrderService
throw new OrderException('没有找到下单用户');
}
// 验证积分余额是否足够
- $profit = $order->score_discount_amount;
- if ($user->profit < $profit) {
- throw new OrderException('e品额不足');
+ $score = $order->score_discount_amount;
+ if ($user->balance < $score) {
+ throw new OrderException('用户积分不足');
}
// 支付金额
@@ -173,13 +173,6 @@ class OrderService
}
$order->save();
- // 扫码付款的订单, 支付成功后, 直接完成
- if ($order->scene === OrderScene::Scan) {
- $order->ship_status = ShipStatus::Finished;
- $order->save();
- $this->receive($order);
- }
-
event(new OrderPaid($order));
}
@@ -206,18 +199,17 @@ class OrderService
$subParam = ['order_goods_id' => $item->id, 'amount' => $item->amount, 'goods_name' => $item->goods_name];
} else {
$filter = array_filter($goods, fn($subItem) => $subItem['order_goods_id'] == $item->id);
- $amount = data_get($filter, '0.amount');
- if ($amount) {
- $subParam = ['order_goods_id' => $item->id, 'amount' => $amount, 'goods_name' => $item->goods_name, 'cover_image' => $item->cover_image];
- }
+ $subItem = array_shift($filter);
+ $amount = data_get($subItem, 'amount', 0);
+ $subParam = ['order_goods_id' => $item->id, 'amount' => $amount, 'goods_name' => $item->goods_name, 'cover_image' => $item->cover_image];
}
- if ($subParam) {
- if ($item->ship_amount + $subParam['amount'] > $item->amount) {
- throw new OrderException($subParam['goods_name'] . ' 发货数量超过购买数量');
- }
- if ($item->ship_amount + $subParam['amount'] < $item->amount) {
- $full = false;
- }
+ if ($item->ship_amount + $subParam['amount'] > $item->amount) {
+ throw new OrderException($subParam['goods_name'] . ' 发货数量超过购买数量');
+ }
+ if ($item->ship_amount + $subParam['amount'] < $item->amount) {
+ $full = false;
+ }
+ if ($subParam['amount']) {
$item->increment('ship_amount', $subParam['amount']);
array_push($params, $subParam);
}
@@ -299,10 +291,6 @@ class OrderService
}
// 订单已经支付, 全额退款
if ($order->pay_status === PayStatus::Success) {
- // 如果赠送给用户积分, 验证用户余额是否足够扣除
- if ($order->user_get_profit > 0 && $order->user->profit < $order->user_get_profit) {
- throw new OrderException('订单无法取消, 用户余额不足');
- }
// 支付金额
if ($order->pay_money > 0) {
diff --git a/src/OrderStore.php b/src/OrderStore.php
index 3c77f88..3be687c 100644
--- a/src/OrderStore.php
+++ b/src/OrderStore.php
@@ -5,7 +5,6 @@ namespace Peidikeji\Order;
use Peidikeji\Coupon\CouponService;
use Peidikeji\Coupon\Models\UserCoupon;
use Peidikeji\Goods\Models\Goods;
-use Peidikeji\Order\Enums\OrderScene;
use Peidikeji\Order\Events\OrderCreated;
use Peidikeji\Order\Exceptions\OrderException;
use Peidikeji\Order\Models\Order;
@@ -19,15 +18,9 @@ class OrderStore
// 商品列表
public $goodsList;
- // 订单场景
- public $scene;
-
// 下单用户
public $user;
- // 指定店铺
- public $merchant;
-
// 订单总额/商品总额
public $money;
@@ -37,28 +30,17 @@ class OrderStore
// amount: 使用积分, money: 积分抵扣金额, ratio: 抵扣比例
public $score = ['amount' => 0, 'money' => 0, 'ratio' => 0];
- // is: 是否Vip, money: 会员累计优惠金额
- public $vip = ['is' => false, 'money' => 0];
-
// address: 配送地址, money: 配送费, way: 配送方式
public $ship = ['address' => null, 'money' => 0, 'way' => null];
// 使用优惠券
public $coupon = ['id' => null, 'money' => 0];
- public function __construct($scene = null)
+ public function __construct()
{
- $this->scene = $scene;
$this->orderGoodsList = collect();
}
- public function scene($scene): static
- {
- $this->scene = $scene;
-
- return $this;
- }
-
public function user($user): static
{
$this->user = $user;
@@ -66,13 +48,6 @@ class OrderStore
return $this;
}
- public function merchant($merchant): static
- {
- $this->merchant = $merchant;
-
- return $this;
- }
-
public function remarks($remarks): static
{
$this->remarks = $remarks;
@@ -84,70 +59,37 @@ class OrderStore
* 购买商品
*
* @param array $params 商品参数 [{id, amount, spec: [{name, value}]}]
- * @param mixed $vip 是否使用Vip价格(null: 根据用户判断, bool: 是否强制使用)
* @throws OrderException
*/
- public function goods(array $params, mixed $vip = null): static
+ public function goods(array $params): static
{
- $merchant = $this->merchant;
- $goodsList = null;
- if ($this->scene === OrderScene::Online->value) {
- $goodsList = Goods::show()->whereNull('merchant_id')->whereIn('id', array_column($params, 'id'))->get();
- } elseif ($this->scene === OrderScene::Merchant->value) {
- $goodsList = Goods::show()->where('merchant_id', $merchant->id)->whereIn('id', array_column($params, 'id'))->get();
- } elseif ($this->scene === OrderScene::Scan->value) {
- $money = $this->money;
- $goodsList = collect()->push([
- 'id' => data_get($params, '0.id'),
- 'name' => $merchant->name,
- 'merchant_id' => $merchant->id,
- 'goods_name' => '线下交易',
- 'cover_image' => $merchant->logo,
- 'price' => $money,
- 'vip_price' => $money,
- 'amount' => 1,
- 'on_sale' => 1,
- 'stock' => 1
- ]);
- }
+ $goodsList = Goods::show()->whereIn('id', array_column($params, 'id'))->get();
if ($goodsList->count() === 0) {
throw new OrderException('请选择有效商品');
}
$orderGoodsList = collect();
- $user = $this->user;
- if ($vip === null && $user) {
- $vip = $user->isVip();
- }
foreach ($params as $item) {
$goods = $goodsList->firstWhere('id', $item['id']);
+ if (!$goods) {
+ throw new OrderException('商品未上架');
+ }
if (! data_get($goods, 'on_sale')) {
throw new OrderException($goods->name.' 未上架');
}
- // 最大抵扣积分
- $scoreRatio = data_get($goods, 'score_max_amount', $merchant->score_max_ratio);
- $price = data_get($goods, $vip ? 'vip_price' : 'price');
- $scoreMaxAmount = $price * $scoreRatio / 100 / Setting::where('slug', 'discount_profit_ratio')->value('value');
-
$stock = data_get($goods, 'stock');
$orderGoods = [
'goods_id' => data_get($goods, 'id'),
- 'merchant_id' => data_get($goods, 'merchant_id'),
'goods_name' => data_get($goods, 'name'),
- 'goods_sn' => data_get($goods, 'sn'),
+ 'goods_sn' => data_get($goods, 'goods_sn'),
'cover_image' => data_get($goods, 'cover_image'),
- 'price' => data_get($goods, 'price'),
- 'vip_price' => data_get($goods, 'vip_price'),
- 'score_max_amount' => $scoreMaxAmount,
+ 'price' => floatval(data_get($goods, 'price')),
'attr' => data_get($goods, 'attr'),
'spec' => data_get($item, 'spec'),
'part' => data_get($item, 'part'),
'amount' => data_get($item, 'amount', 1),
'money' => 0,
- 'shipping_tmp_id' => data_get($goods, 'shipping_tmp_id'),
- 'weight' => data_get($goods, 'weight'),
- 'volume' => data_get($goods, 'volume'),
];
if (data_get($item, 'spec')) {
$sku = $goods->skus()->jsonArray($item['spec'])->first();
@@ -157,11 +99,7 @@ class OrderStore
$stock = $sku->stock;
$orderGoods['goods_sku_id'] = $sku->id;
$orderGoods['goods_sku_sn'] = $sku->sn;
- $orderGoods['vip_price'] = $sku->vip_price;
- $orderGoods['price'] = $sku->price;
- $orderGoods['shipping_tmp_id'] = $sku->shipping_tmp_id;
- $orderGoods['weight'] = $sku->weight;
- $orderGoods['volume'] = $sku->volume;
+ $orderGoods['price'] = floatval($sku->price);
}
if ($orderGoods['amount'] > $stock) {
@@ -176,7 +114,6 @@ class OrderStore
$this->goodsList = $goodsList;
$this->orderGoodsList = $orderGoodsList;
$this->money = $orderGoodsList->sum('money');
- $this->vip = ['is' => $vip, 'money' => $vip ? $orderGoodsList->sum(fn ($item) => $item['price'] - $item['vip_price']) : 0];
return $this;
}
@@ -211,19 +148,6 @@ class OrderStore
$this->coupon = ['id' => $info->id, 'money' => $couponMoney];
}
- /**
- * 设置订单总金额
- */
- public function money($money)
- {
- if ($this->scene !== OrderScene::Scan->value) {
- throw new OrderException('非扫码付款, 无法设置订单金额');
- }
- $this->money = $money;
-
- return $this;
- }
-
/**
* 使用积分抵扣
*
@@ -236,21 +160,11 @@ class OrderStore
{
$user = $this->user;
if ($amount > 0 && $user) {
- // 最大抵扣数量
- $maxAmount = $this->orderGoodsList->sum('score_max_amount');
- if ($amount > $maxAmount) {
- throw new OrderException($maxAmount > 0 ? '本次订单最多使用 '.$maxAmount.' 积分抵扣' : '订单不支持使用积分抵扣');
- }
-
- if ($user->profit < $amount) {
+ if ($user->balance < $amount) {
throw new OrderException('用户积分不足');
}
- if ($ratio === null) {
- $ratio = round(Setting::where('slug', 'discount_profit_ratio')->value('value'), 2, PHP_ROUND_HALF_DOWN);
- }
- if ($ratio === null) {
- throw new OrderException('未配置积分抵扣比例');
- }
+ // 积分抵扣比例: 1 积分 = ? 金额
+ $ratio = 1;
if ($money === null) {
$money = $amount * $ratio;
}
@@ -274,9 +188,7 @@ class OrderStore
'sn' => OrderService::make()->generateSn(),
]);
- $order->scene = $this->scene;
$order->user_id = $this->user?->id;
- $order->merchant_id = $this->merchant?->id;
$order->ship_address = $this->ship['address'];
$order->ship_way = $this->ship['way'];
$order->ship_money = $this->ship['money'];
@@ -287,13 +199,12 @@ class OrderStore
$order->score_discount_ratio = $this->score['ratio'];
$order->score_discount_money = $this->score['money'];
- $order->coupon_money = $this->coupon['money'];
- $order->coupon_id = $this->coupon['id'];
-
- $order->vip_discount_money = $this->vip['money'];
+ if ($this->coupon['id']) {
+ $order->coupon_money = $this->coupon['money'];
+ $order->coupon_id = $this->coupon['id'];
+ }
$order->pay_money = $this->getPayMoney();
- $order->user_get_profit = $this->getUserBonus($order->pay_money);
$order->save();
$order->goods()->createMany($this->orderGoodsList);
@@ -315,9 +226,6 @@ class OrderStore
// 积分抵扣
$money -= $this->score['money'];
- // Vip 优惠
- $money -= $this->vip['money'];
-
// 优惠券抵扣
$money -= $this->coupon['money'];
@@ -327,29 +235,6 @@ class OrderStore
return max($money, 0);
}
- /**
- * 用户应得奖励
- *
- * @param float|null $payMoney 支付金额
- * @return float
- * @throws OrderException
- */
- public function getUserBonus(float $payMoney = null): float
- {
- $money = 0;
-
- if ($this->merchant) {
- $payMoney = is_null($payMoney) ? $this->getPayMoney() : $payMoney;
- $money = floor($payMoney * ($this->merchant->profit_ratio / 100));
- $merchantUser = $this->merchant->user;
- if ($merchantUser->profit < $money) {
- throw new OrderException('店铺返现账户余额不足');
- }
- }
-
- return $money;
- }
-
public static function init(...$params): static
{
return new static(...$params);