161 lines
4.8 KiB
PHP
161 lines
4.8 KiB
PHP
<?php
|
|
|
|
namespace App\Admin\Controllers;
|
|
|
|
use App\Admin\Actions\Grid\CreateOrderPackage;
|
|
use App\Admin\Repositories\Order;
|
|
use App\Models\Order as OrderModel;
|
|
use App\Models\OrderProduct;
|
|
use Dcat\Admin\Form;
|
|
use Dcat\Admin\Grid;
|
|
use Dcat\Admin\Http\Controllers\AdminController;
|
|
use Dcat\Admin\Show;
|
|
use Illuminate\Http\Request;
|
|
|
|
class OrderController extends AdminController
|
|
{
|
|
/**
|
|
* Make a grid builder.
|
|
*
|
|
* @return Grid
|
|
*/
|
|
protected function grid()
|
|
{
|
|
$order = Order::with('user');
|
|
return Grid::make(new Order(), function (Grid $grid) {
|
|
$grid->column('id')->sortable();
|
|
$grid->column('sn');
|
|
$grid->column('user.phone');
|
|
// $grid->column('user_coupon_id');
|
|
// $grid->column('coupon_discount_amount');
|
|
$grid->column('products_total_amount');
|
|
$grid->column('vip_discount_amount');
|
|
$grid->column('coupon_discount_amount');
|
|
$grid->column('reduced_amount');
|
|
$grid->column('weight');
|
|
$grid->column('shipping_fee');
|
|
$grid->column('total_amount');
|
|
// $grid->column('note');
|
|
// $grid->column('remark');
|
|
// $grid->column('pay_sn');
|
|
$grid->column('pay_way');
|
|
// $grid->column('pay_at');
|
|
// $grid->column('consignee_name');
|
|
// $grid->column('consignee_telephone');
|
|
// $grid->column('consignee_zone');
|
|
// $grid->column('consignee_address');
|
|
$grid->column('status');
|
|
// $grid->column('completed_at');
|
|
$grid->column('created_at')->sortable();
|
|
|
|
$grid->actions(function (Grid\Displayers\Actions $actions) {
|
|
$actions->append(new CreateOrderPackage());
|
|
});
|
|
|
|
$grid->filter(function (Grid\Filter $filter) {
|
|
$filter->equal('id');
|
|
});
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Make a show builder.
|
|
*
|
|
* @param mixed $id
|
|
*
|
|
* @return Show
|
|
*/
|
|
protected function detail($id)
|
|
{
|
|
return Show::make($id, new Order(), function (Show $show) {
|
|
$show->field('id');
|
|
$show->field('user_id');
|
|
$show->field('sn');
|
|
$show->field('user_coupon_id');
|
|
$show->field('coupon_discount_amount');
|
|
$show->field('vip_discount_amount');
|
|
$show->field('reduced_amount');
|
|
$show->field('shipping_fee');
|
|
$show->field('products_total_amount');
|
|
$show->field('total_amount');
|
|
$show->field('weight');
|
|
$show->field('note');
|
|
$show->field('remark');
|
|
$show->field('pay_sn');
|
|
$show->field('pay_way');
|
|
$show->field('pay_at');
|
|
$show->field('consignee_name');
|
|
$show->field('consignee_telephone');
|
|
$show->field('consignee_zone');
|
|
$show->field('consignee_address');
|
|
$show->field('status');
|
|
$show->field('completed_at');
|
|
$show->field('created_at');
|
|
$show->field('updated_at');
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Make a form builder.
|
|
*
|
|
* @return Form
|
|
*/
|
|
protected function form()
|
|
{
|
|
return Form::make(new Order(), function (Form $form) {
|
|
$form->display('id');
|
|
$form->text('user_id');
|
|
$form->text('sn');
|
|
$form->text('user_coupon_id');
|
|
$form->text('coupon_discount_amount');
|
|
$form->text('vip_discount_amount');
|
|
$form->text('reduced_amount');
|
|
$form->text('shipping_fee');
|
|
$form->text('products_total_amount');
|
|
$form->text('total_amount');
|
|
$form->text('weight');
|
|
$form->text('note');
|
|
$form->text('remark');
|
|
$form->text('pay_sn');
|
|
$form->text('pay_way');
|
|
$form->text('pay_at');
|
|
$form->text('consignee_name');
|
|
$form->text('consignee_telephone');
|
|
$form->text('consignee_zone');
|
|
$form->text('consignee_address');
|
|
$form->text('status');
|
|
$form->text('completed_at');
|
|
|
|
$form->display('created_at');
|
|
$form->display('updated_at');
|
|
});
|
|
}
|
|
|
|
public function orders(Request $request)
|
|
{
|
|
$sn = $request->input('q');
|
|
|
|
$query = OrderModel::select('id', 'sn as text');
|
|
|
|
if ($sn) {
|
|
$query->where('sn', 'like', "%$sn%");
|
|
return $query->paginate(null);
|
|
}
|
|
|
|
return response()->json($query->get());
|
|
}
|
|
|
|
public function orderProducts(Request $request)
|
|
{
|
|
$orderId = $request->input('q');
|
|
|
|
$query = OrderProduct::select('id', 'name as text');
|
|
|
|
if ($orderId) {
|
|
$query->where('order_id', $orderId);
|
|
}
|
|
|
|
return response()->json($query->get());
|
|
}
|
|
}
|