6
0
Fork 0

添加订单除发货外操作

release
vine_liutk 2021-12-17 14:50:49 +08:00
parent f355f9e40b
commit a317bf06bf
17 changed files with 739 additions and 59 deletions

View File

@ -0,0 +1,32 @@
<?php
namespace App\Admin\Actions\Show;
use App\Admin\Forms\OrderConsigneeInfo as OrderConsigneeInfoForm;
use Dcat\Admin\Show\AbstractTool;
use Dcat\Admin\Widgets\Modal;
class OrderConsigneeInfo extends AbstractTool
{
/**
* @return string
*/
protected $title = '<i class="feather icon-external-link"></i>&nbsp;修改订单地址';
/**
* 按钮样式定义,默认 btn btn-white waves-effect
*
* @var string
*/
protected $style = 'btn-success';
public function render()
{
$form = OrderConsigneeInfoForm::make()->payload(['id'=>$this->getKey()]);
return Modal::make()
->lg()
->title($this->title)
->body($form)
->button("<a href=\"javascript:void(0)\" class=\"btn btn-sm {$this->style}\">{$this->title}</a>&nbsp;&nbsp;");
}
}

View File

@ -0,0 +1,39 @@
<?php
namespace App\Admin\Actions\Show;
use App\Admin\Forms\OrderPackage;
use Dcat\Admin\Show\AbstractTool;
use Dcat\Admin\Widgets\Modal;
class OrderCreatePackage extends AbstractTool
{
public function __construct($title = null, $id)
{
if ($title) {
$this->title = $title;
}
$this->setKey($id);
}
/**
* @return string
*/
protected $title = '<i class="feather icon-package"></i>&nbsp;发货';
/**
* 按钮样式定义,默认 btn btn-white waves-effect
*
* @var string
*/
protected $style = 'btn-warning';
public function render()
{
$form = OrderPackage::make()->payload(['id'=>$this->getKey()]);
return Modal::make()
->lg()
->title($this->title)
->body($form)
->button("<a href=\"javascript:void(0)\" class=\"btn btn-sm {$this->style}\">{$this->title}</a>&nbsp;&nbsp;");
}
}

View File

@ -0,0 +1,82 @@
<?php
namespace App\Admin\Actions\Show;
use App\Models\Order;
use App\Services\OrderService;
use Dcat\Admin\Show\AbstractTool;
use Illuminate\Contracts\Auth\Authenticatable;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use Throwable;
class OrderPay extends AbstractTool
{
/**
* @return string
*/
protected $title = '<i class="fa fa-jpy icon-shuffle"></i>&nbsp;支付';
/**
* 按钮样式定义,默认 btn btn-white waves-effect
*
* @var string
*/
protected $style = 'btn btn-sm btn-danger';
/**
* 权限判断,如不需要可以删除此方法
*
* @param Model|Authenticatable|HasPermissions|null $user
*
* @return bool
*/
protected function authorize($user): bool
{
return $user->can('dcat.admin.orders.pay');
}
/**
* 处理请求,如果不需要接口处理,请直接删除这个方法
*
* @param Request $request
*
* @return Response
*/
public function handle(Request $request)
{
// 获取主键
$key = $this->getKey();
$orderService = new OrderService();
$order = Order::where('status', Order::STATUS_PENDING)->findOrFail($key);
try {
DB::beginTransaction();
$orderService->adminPay($order);
DB::commit();
} catch (Throwable $th) {
DB::rollBack();
report($th);
return $this->response()->error('操作失败:'.$th->getMessage());
}
return $this->response()
->success(__('admin.update_succeeded'))
->refresh();
}
public function html()
{
return parent::html().'&nbsp;&nbsp;';
}
/**
* 确认弹窗信息,如不需要可以删除此方法
*
* @return string|array|void
*/
public function confirm()
{
return ['是否改变订单支付状态?', '该操作不可逆,确认后将修改为支付状态。'];
}
}

View File

@ -0,0 +1,32 @@
<?php
namespace App\Admin\Actions\Show;
use App\Admin\Forms\OrderReduce as OrderReduceForm;
use Dcat\Admin\Show\AbstractTool;
use Dcat\Admin\Widgets\Modal;
class OrderReduce extends AbstractTool
{
/**
* @return string
*/
protected $title = '<i class="feather icon-shuffle"></i>&nbsp;改价';
/**
* 按钮样式定义,默认 btn btn-white waves-effect
*
* @var string
*/
protected $style = 'btn-success';
public function render()
{
$form = OrderReduceForm::make()->payload(['id'=>$this->getKey()]);
return Modal::make()
->lg()
->title($this->title)
->body($form)
->button("<a href=\"javascript:void(0)\" class=\"btn btn-sm {$this->style}\">{$this->title}</a>&nbsp;&nbsp;");
}
}

View File

@ -0,0 +1,32 @@
<?php
namespace App\Admin\Actions\Show;
use App\Admin\Forms\OrderRemark as OrderRemarkForm;
use Dcat\Admin\Show\AbstractTool;
use Dcat\Admin\Widgets\Modal;
class OrderRemark extends AbstractTool
{
/**
* @return string
*/
protected $title = '<i class="feather icon-file-text"></i>&nbsp;备注';
/**
* 按钮样式定义,默认 btn btn-white waves-effect
*
* @var string
*/
protected $style = 'btn-success';
public function render()
{
$form = OrderRemarkForm::make()->payload(['id'=>$this->getKey()]);
return Modal::make()
->lg()
->title($this->title)
->body($form)
->button("<a href=\"javascript:void(0)\" class=\"btn btn-sm {$this->style}\">{$this->title}</a>&nbsp;&nbsp;");
}
}

View File

@ -3,11 +3,18 @@
namespace App\Admin\Controllers; namespace App\Admin\Controllers;
use App\Admin\Actions\Grid\CreateOrderPackage; use App\Admin\Actions\Grid\CreateOrderPackage;
use App\Admin\Actions\Show\OrderConsigneeInfo;
use App\Admin\Actions\Show\OrderCreatePackage;
use App\Admin\Actions\Show\OrderPay;
use App\Admin\Actions\Show\OrderReduce;
use App\Admin\Actions\Show\OrderRemark;
use App\Admin\Repositories\Order; use App\Admin\Repositories\Order;
use App\Constants\OrderStatus;
use App\Models\Order as OrderModel; use App\Models\Order as OrderModel;
use App\Models\OrderLog; use App\Models\OrderLog;
use App\Models\OrderPackage; use App\Models\OrderPackage;
use App\Models\OrderProduct; use App\Models\OrderProduct;
use Dcat\Admin\Admin;
use Dcat\Admin\Form; use Dcat\Admin\Form;
use Dcat\Admin\Grid; use Dcat\Admin\Grid;
use Dcat\Admin\Http\Controllers\AdminController; use Dcat\Admin\Http\Controllers\AdminController;
@ -30,62 +37,59 @@ class OrderController extends AdminController
$grid->column('id')->sortable(); $grid->column('id')->sortable();
$grid->column('sn'); $grid->column('sn');
$grid->column('user.phone'); $grid->column('user.phone');
// $grid->column('user_coupon_id');
// $grid->column('coupon_discount_amount');
// $grid->column('products_total_amount')->display(function ($value) {
// return bcdiv($value, 100, 2);
// })->prepend('¥');
// $grid->column('vip_discount_amount')->display(function ($value) {
// return bcdiv($value, 100, 2);
// })->prepend('¥');
// $grid->column('coupon_discount_amount')->display(function ($value) {
// return bcdiv($value, 100, 2);
// })->prepend('¥');
// $grid->column('reduced_amount')->display(function ($value) {
// return bcdiv($value, 100, 2);
// })->prepend('¥');
// $grid->column('weight');
// $grid->column('shipping_fee')->display(function ($value) {
// return bcdiv($value, 100, 2);
// })->prepend('¥');
$grid->column('total_amount')->display(function ($value) { $grid->column('total_amount')->display(function ($value) {
return bcdiv($value, 100, 2); return bcdiv($value, 100, 2);
})->prepend('¥'); })->prepend('¥');
// $grid->column('note'); $grid->column('order_status')->display(function ($value) {
// $grid->column('remark'); return $this->order_status;
// $grid->column('pay_sn'); })->using([
0=>'待付款',
1=>'待发货',
2=>'发货中',
3=>'已发货',
9=>'已完成',
10=>'已取消',
])->dot([
0=>'primary',
1=>'warning',
2=>'danger',
3=>'success',
9=>'success',
10=>'#b3b9bf',
]);
$grid->column('pay_way'); $grid->column('pay_way');
$grid->column('pay_at'); $grid->column('pay_at');
// $grid->column('consignee_name'); // $grid->column('consignee_name');
// $grid->column('consignee_telephone'); // $grid->column('consignee_telephone');
// $grid->column('consignee_zone'); // $grid->column('consignee_zone');
// $grid->column('consignee_address'); // $grid->column('consignee_address');
$grid->column('status')->using([
0=>'待支付', // $grid->column('status')->using([
1=>'待收货', // 0=>'待支付',
9=>'已完成', // 1=>'待收货',
10=>'已取消', // 9=>'已完成',
])->dot([ // 10=>'已取消',
0=>'primary', // ])->dot([
1=>'danger', // 0=>'primary',
9=>'success', // 1=>'danger',
10=>'#b3b9bf', // 9=>'success',
]); // 10=>'#b3b9bf',
$grid->column('shipping_state')->display(function ($v) { // ]);
if ($this->status <1) { // $grid->column('shipping_state')->display(function ($v) {
return -1; // if ($this->status <1) {
} // return -1;
return $v; // }
})->using([ // return $v;
-1=> '-', // })->using([
0 => '待发货', // -1=> '-',
1 => '发货中', // 0 => '待发货',
2 => '已完成', // 1 => '发货中',
])->dot([ // 2 => '已完成',
0 => 'primary', // ])->dot([
1 => 'danger', // 0 => 'primary',
2 => 'success', // 1 => 'danger',
]); // 2 => 'success',
// ]);
// $grid->column('completed_at'); // $grid->column('completed_at');
$grid->column('created_at')->sortable(); $grid->column('created_at')->sortable();
@ -115,8 +119,25 @@ class OrderController extends AdminController
$row->column(5, function ($column) use ($id) { $row->column(5, function ($column) use ($id) {
$builder = Order::with(['user', 'userCoupon']); $builder = Order::with(['user', 'userCoupon']);
$column->row(Show::make($id, $builder, function (Show $show) { $column->row(Show::make($id, $builder, function (Show $show) {
$show->field('id'); // $show->field('id');
$show->field('sn'); $show->field('sn');
$show->field('order_status')->as(function ($v) {
return $this->order_status;
})->using([
0=>'待付款',
1=>'待发货',
2=>'发货中',
3=>'已发货',
9=>'已完成',
10=>'已取消',
])->dot([
0=>'primary',
1=>'warning',
2=>'danger',
3=>'success',
9=>'success',
10=>'#b3b9bf',
]);
$show->field('total_amount')->as(function ($v) { $show->field('total_amount')->as(function ($v) {
return bcdiv($v, 100, 2); return bcdiv($v, 100, 2);
})->prepend('¥'); })->prepend('¥');
@ -124,7 +145,14 @@ class OrderController extends AdminController
$show->field('pay_way'); $show->field('pay_way');
$show->field('pay_at'); $show->field('pay_at');
$show->field('user.phone'); $show->divider();
$show->field('consignee_name');
$show->field('consignee_telephone');
$show->field('consignee')->as(function () {
return $this->consignee_zone . ' '. $this->consignee_address;
});
// $show->field('user.phone');
$show->divider();
$show->field('products_total_amount')->as(function ($v) { $show->field('products_total_amount')->as(function ($v) {
return bcdiv($v, 100, 2); return bcdiv($v, 100, 2);
})->prepend('¥'); })->prepend('¥');
@ -141,12 +169,25 @@ class OrderController extends AdminController
$show->field('shipping_fee')->as(function ($v) { $show->field('shipping_fee')->as(function ($v) {
return bcdiv($v, 100, 2); return bcdiv($v, 100, 2);
})->prepend('¥'); })->prepend('¥');
$show->divider();
$show->field('note');
$show->field('remark');
$show->panel() $show->panel()
->tools(function (Show\Tools $tools) use ($show) { ->tools(function (Show\Tools $tools) use ($show) {
$tools->disableEdit(); $tools->disableEdit();
$tools->disableDelete(); $tools->disableDelete();
if ($show->model()->status == OrderModel::STATUS_PENDING) {
if (Admin::user()->can('dcat.admin.orders.reduce')) {
$tools->append(new OrderReduce());
}
if (Admin::user()->can('dcat.admin.orders.pay')) {
$tools->append(new OrderPay());
}
}
$tools->append(new OrderRemark());
$tools->append(new OrderConsigneeInfo());
}); });
})); }));
}); });
@ -181,6 +222,8 @@ class OrderController extends AdminController
$grid->column('shipping_number', '物流单号'); $grid->column('shipping_number', '物流单号');
$grid->column('packageProducts', '包裹商品')->setHeaderAttributes(['style' => 'color:#5b69bc']); $grid->column('packageProducts', '包裹商品')->setHeaderAttributes(['style' => 'color:#5b69bc']);
$grid->column('created_at', '发货时间'); $grid->column('created_at', '发货时间');
$grid->column('status', '包裹状态');
$grid->model()->orderBy('created_at', 'desc');
$grid->disableActions(); $grid->disableActions();
$grid->disablePagination(); $grid->disablePagination();
@ -188,9 +231,12 @@ class OrderController extends AdminController
}); });
$logBuilder = OrderLog::with('administrator')->where('order_id', $id); $logBuilder = OrderLog::with('administrator')->where('order_id', $id);
$orderLogoGrid = Grid::make($logBuilder, function (Grid $grid) { $orderLogoGrid = Grid::make($logBuilder, function (Grid $grid) {
$grid->column('administrator', '操作人'); $grid->column('administrator.name', '操作人');
$grid->column('content', '操作明细'); $grid->column('content', '操作明细')->display(function ($content) {
$grid->column('craeted_at', '操作时间'); return $content;
});
$grid->column('created_at', '操作时间');
$grid->model()->orderBy('created_at', 'desc');
$grid->disableActions(); $grid->disableActions();
$grid->disablePagination(); $grid->disablePagination();
@ -199,12 +245,13 @@ class OrderController extends AdminController
$column->row(Box::make('订单商品', $productGrid)); $column->row(Box::make('订单商品', $productGrid));
$packagesBox = Box::make('发货包裹', $packageGrid); $packagesBox = Box::make('发货包裹', $packageGrid);
$packagesBox->tool('<button class="btn btn-sm btn-light shadow-none">发货</button>'); //显示发货动作
if (in_array(OrderModel::findOrFail($id)->orderStatus, [OrderStatus::PAID, OrderStatus::SHIPPING])) {
$packagesBox->tool(new OrderCreatePackage(null, $id));
}
$column->row($packagesBox->collapsable()); $column->row($packagesBox->collapsable());
$logsBox = Box::make('操作记录', $orderLogoGrid); $logsBox = Box::make('操作记录', $orderLogoGrid);
$logsBox->tool('<button class="btn btn-sm btn-light shadow-none">改价</button>');
$logsBox->tool('<button class="btn btn-sm btn-light shadow-none">支付</button>');
$logsBox->tool('<button class="btn btn-sm btn-light shadow-none">修改收货地址</button>');
$column->row($logsBox->collapsable()); $column->row($logsBox->collapsable());
}); });
}; };

View File

@ -0,0 +1,71 @@
<?php
namespace App\Admin\Forms;
use App\Exceptions\BizException;
use App\Models\Order;
use App\Services\OrderService;
use Dcat\Admin\Contracts\LazyRenderable;
use Dcat\Admin\Traits\LazyWidget;
use Dcat\Admin\Widgets\Form;
use Illuminate\Support\Facades\DB;
use Throwable;
class OrderConsigneeInfo extends Form implements LazyRenderable
{
use LazyWidget;
/**
* 权限判断,如不需要可以删除此方法
*
* @param Model|Authenticatable|HasPermissions|null $user
*
* @return bool
*/
protected function authorize($user): bool
{
return $user->can('dcat.admin.orders.consignee');
}
/**
* Handle the form request.
*
* @param array $input
*
* @return mixed
*/
public function handle(array $input)
{
$orderId = $this->payload['id'] ?? 0;
$order = Order::findOrFail($orderId);
$orderService = new OrderService();
try {
DB::beginTransaction();
$orderService->adminEditConsignee($order, $input);
DB::commit();
} catch (Throwable $th) {
DB::rollBack();
report($th);
throw new BizException('操作失败:'.$th->getMessage());
}
return $this->response()
->success(__('admin.update_succeeded'))
->refresh();
}
/**
* Build a form here.
*/
public function form()
{
$orderId = $this->payload['id'] ?? 0;
$order = Order::findOrFail($orderId);
$this->text('consignee_name')->required()->value($order->consignee_name);
$this->text('consignee_telephone')->required()->value($order->consignee_telephone);
$this->text('consignee_zone')->required()->value($order->consignee_zone);
$this->text('consignee_address')->required()->value($order->consignee_address);
$this->disableResetButton();
}
}

View File

@ -43,7 +43,7 @@ class OrderPackage extends Form implements LazyRenderable
*/ */
public function form() public function form()
{ {
$orderId = $this->payload['order_id'] ?? 0; $orderId = $this->payload['id'] ?? 0;
$order = Order::findOrFail($orderId); $order = Order::findOrFail($orderId);
$this->hidden('order_id'); $this->hidden('order_id');
@ -51,7 +51,7 @@ class OrderPackage extends Form implements LazyRenderable
$this->text('shipping_company'); $this->text('shipping_company');
$this->text('shipping_number'); $this->text('shipping_number');
$this->hasMany('packages', function (Form $form) use ($order) { $this->hasMany('packages', function (Form $form) use ($order) {
$form->select('order_product_id')->options($order->products->pluck('name', 'id')); $form->select('order_product_id')->options($order->products()->where('after_sale_state', '<>', 1)->pluck('name', 'id'));
$form->number('quantity')->min(0); $form->number('quantity')->min(0);
}); });

View File

@ -0,0 +1,90 @@
<?php
namespace App\Admin\Forms;
use App\Exceptions\BizException;
use App\Models\Order;
use App\Services\OrderService;
use Dcat\Admin\Admin;
use Dcat\Admin\Contracts\LazyRenderable;
use Dcat\Admin\Traits\LazyWidget;
use Dcat\Admin\Widgets\Form;
use Illuminate\Support\Facades\DB;
use Throwable;
class OrderReduce extends Form implements LazyRenderable
{
use LazyWidget;
/**
* 权限判断,如不需要可以删除此方法
*
* @param Model|Authenticatable|HasPermissions|null $user
*
* @return bool
*/
protected function authorize($user): bool
{
return $user->can('dcat.admin.orders.reduce');
}
/**
* Handle the form request.
*
* @param array $input
*
* @return mixed
*/
public function handle(array $input)
{
$orderId = $this->payload['id'] ?? 0;
$order = Order::findOrFail($orderId);
$reduceAmount = $input['reduce_amount']??0;
//获取调整价格;
if ($reduceAmount > $order->total_amount) {
throw new BizException('订单价格无法上浮');
}
if ($reduceAmount == $order->total_amount) {
throw new BizException('调整价格和订单原价格一致,无需调整');
}
$orderService = new OrderService();
$reduced = $order->total_amount-$reduceAmount;
//判断是否在当前操作人调价权限范围内
if (!Admin::user()->inReduceRange($reduced)) {
throw new BizException('当前调整价格超出权限范围,请重新确认价格。');
}
try {
DB::beginTransaction();
$orderService->adminReduceOrder($order, $reduceAmount);
DB::commit();
} catch (Throwable $th) {
DB::rollBack();
report($th);
throw new BizException('操作失败:'.$th->getMessage());
}
return $this->response()
->success(__('admin.update_succeeded'))
->refresh();
}
/**
* Build a form here.
*/
public function form()
{
$orderId = $this->payload['id'] ?? 0;
$order = Order::findOrFail($orderId);
$this->currency('reduce_amount', '调整价格')->symbol('¥')->default(0)->customFormat(function ($V) use ($order) {
return bcdiv($order->total_amount, 100, 2);
})->saving(function ($reduceAmount) {
return bcmul($reduceAmount, 100);
});
$this->confirm('是否确认调价?', '该操作不可逆,确认后将更改订单支付价格。');
$this->disableResetButton();
}
}

View File

@ -0,0 +1,70 @@
<?php
namespace App\Admin\Forms;
use App\Exceptions\BizException;
use App\Models\Order;
use App\Services\OrderService;
use Dcat\Admin\Contracts\LazyRenderable;
use Dcat\Admin\Traits\LazyWidget;
use Dcat\Admin\Widgets\Form;
use Illuminate\Support\Facades\DB;
use Throwable;
class OrderRemark extends Form implements LazyRenderable
{
use LazyWidget;
/**
* 权限判断,如不需要可以删除此方法
*
* @param Model|Authenticatable|HasPermissions|null $user
*
* @return bool
*/
protected function authorize($user): bool
{
return $user->can('dcat.admin.orders.remark');
}
/**
* Handle the form request.
*
* @param array $input
*
* @return mixed
*/
public function handle(array $input)
{
$orderId = $this->payload['id'] ?? 0;
$order = Order::findOrFail($orderId);
$remark = $input['remark']??'';
$orderService = new OrderService();
try {
DB::beginTransaction();
$orderService->adminRemark($order, $remark);
DB::commit();
} catch (Throwable $th) {
DB::rollBack();
report($th);
throw new BizException('操作失败:'.$th->getMessage());
}
return $this->response()
->success(__('admin.update_succeeded'))
->refresh();
}
/**
* Build a form here.
*/
public function form()
{
$orderId = $this->payload['id'] ?? 0;
$order = Order::findOrFail($orderId);
$this->text('remark')->required()->value($order->remark);
$this->disableResetButton();
}
}

View File

@ -2,6 +2,7 @@
namespace App\Models\Admin; namespace App\Models\Admin;
use App\Models\OrderReduceRange;
use Dcat\Admin\Models\Administrator as DcatAdministrator; use Dcat\Admin\Models\Administrator as DcatAdministrator;
class Administrator extends DcatAdministrator class Administrator extends DcatAdministrator
@ -49,4 +50,28 @@ class Administrator extends DcatAdministrator
{ {
session()->forget(self::SESSION_KEY); session()->forget(self::SESSION_KEY);
} }
/**
* 管理员订单调价范围
*
* @return void
*/
public function orderReduceRange()
{
return $this->hasOne(OrderReduceRange::class, 'administrator_id');
}
/**
* 在调价权限范围内
*
* @param integer $reduced
* @return void
*/
public function inReduceRange(int $reduced)
{
if (is_null($this->orderReduceRange)) {
return false;
}
return $reduced <= $this->orderReduceRange->max;
}
} }

View File

@ -114,6 +114,16 @@ class Order extends Model
return $this->hasMany(OrderProduct::class); return $this->hasMany(OrderProduct::class);
} }
/**
* 此订单是否待付款
*
* @return boolean
*/
public function isPending(): bool
{
return $this->status === static::STATUS_PENDING;
}
/** /**
* 确认此订单是否可以被确认 * 确认此订单是否可以被确认
* *

View File

@ -3,6 +3,7 @@
namespace App\Models; namespace App\Models;
use App\Models\Admin\Administrator; use App\Models\Admin\Administrator;
use Dcat\Admin\Admin;
use Dcat\Admin\Traits\HasDateTimeFormatter; use Dcat\Admin\Traits\HasDateTimeFormatter;
use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Model;
@ -12,6 +13,10 @@ class OrderLog extends Model
use HasFactory; use HasFactory;
use HasDateTimeFormatter; use HasDateTimeFormatter;
protected $fillable = [
'order_id', 'content',
];
public function administrator() public function administrator()
{ {
return $this->belongsTo(Administrator::class, 'administrator_id'); return $this->belongsTo(Administrator::class, 'administrator_id');
@ -21,4 +26,15 @@ class OrderLog extends Model
{ {
return $this->belongsTo(Order::class, 'order_id'); return $this->belongsTo(Order::class, 'order_id');
} }
/**
* {@inheritdoc}
*/
protected static function booted()
{
parent::saving(function ($log) {
// 如果自动创建sn
$log->administrator_id = Admin::user()->id;
});
}
} }

View File

@ -0,0 +1,13 @@
<?php
namespace App\Models;
use Dcat\Admin\Traits\HasDateTimeFormatter;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class OrderReduceRange extends Model
{
use HasFactory;
use HasDateTimeFormatter;
}

View File

@ -10,6 +10,7 @@ use App\Exceptions\ShippingNotSupportedException;
use App\Helpers\Numeric; use App\Helpers\Numeric;
use App\Helpers\Order as OrderHelper; use App\Helpers\Order as OrderHelper;
use App\Models\Order; use App\Models\Order;
use App\Models\OrderLog;
use App\Models\OrderProduct; use App\Models\OrderProduct;
use App\Models\ProductSku; use App\Models\ProductSku;
use App\Models\ShippingAddress; use App\Models\ShippingAddress;
@ -568,4 +569,84 @@ class OrderService
return $user->shippingAddresses()->where('is_default', true)->first(); return $user->shippingAddresses()->where('is_default', true)->first();
} }
/**
* 订单调整价格
*
* @return void
*/
public function adminReduceOrder(Order $order, int $reduceAmount)
{
if ($order->isPending()) {
$res = $order->where('updated_at', $order->updated_at)->update([
'reduced_amount' => $order->total_amount - $reduceAmount + $order->reduced_amount,
'total_amount' => $reduceAmount,
]);
if ($res === 0) {
throw new BizException('订单已发生改变');
}
OrderLog::create([
'order_id'=>$order->id,
'content'=> '调整订单支付价格为:¥'.bcdiv($reduceAmount, 100, 2),
]);
}
}
/**
* 后台支付订单
*
* @param Order $order
* @return void
*/
public function adminPay(Order $order)
{
if ($order->isPending()) {
//操作订单状态-需要调整为统一支付方法
$order->update([
'status' => Order::STATUS_PAID,
]);
OrderLog::create([
'order_id'=>$order->id,
'content'=> '改变订单状态为【已支付】',
]);
}
}
/**
* 添加后台备注
*
* @param Order $order
* @param string $remark
* @return void
*/
public function adminRemark(Order $order, string $remark)
{
//操作订单状态-需要调整为统一支付方法
$order->update([
'remark' => $remark,
]);
OrderLog::create([
'order_id'=>$order->id,
'content'=> '修改订单备注:'.$remark,
]);
}
/**
* 修改订单收货信息
*
* @param Order $order
* @param array $params
* @return void
*/
public function adminEditConsignee(Order $order, array $params)
{
$oldOrderConsignee = $order->consignee_name.','.$order->consignee_telephone.','.$order->consignee_zone.$order->consignee_address;
$order->update($params);
OrderLog::create([
'order_id'=>$order->id,
'content'=> '修改订单收货信息<br\>原收货信息:'.$oldOrderConsignee,
]);
}
} }

View File

@ -0,0 +1,33 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
class CreateOrderReduceRangesTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('order_reduce_ranges', function (Blueprint $table) {
$table->id();
$table->unsignedBigInteger('administrator_id')->comment('操作人ID');
$table->unsignedInteger('max')->default(0)->comment('最大额度');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::dropIfExists('order_reduce_ranges');
}
}

View File

@ -31,7 +31,9 @@ return [
'consignee_telephone' => '联系方式', 'consignee_telephone' => '联系方式',
'consignee_zone' => '收货地区', 'consignee_zone' => '收货地区',
'consignee_address' => '收货地址', 'consignee_address' => '收货地址',
'consignee'=>'收货地址',
'status' => '订单状态', 'status' => '订单状态',
'order_status'=>'订单状态',
'shipping_state'=>'物流状态', 'shipping_state'=>'物流状态',
'completed_at' => '完成时间', 'completed_at' => '完成时间',
'created_at' => '下单时间', 'created_at' => '下单时间',
@ -41,6 +43,11 @@ return [
'quantity' => '数量', 'quantity' => '数量',
'after_sale_state'=>'售后状态', 'after_sale_state'=>'售后状态',
'product_total_amount'=>'总价', 'product_total_amount'=>'总价',
'shipping_company' => '快递公司',
'shipping_number' => '快递单号',
'packages'=>'包裹内容',
'order_product_id' =>'商品',
'quantity'=>'数量',
], ],
'options' => [ 'options' => [
], ],