model() ->where('type', Order::TYPE_SAMPLE) ->with(['shop', 'user', 'items']) ->withCount('versions'); $grid->disableCreateButton(); $grid->quickSearch('order_no')->placeholder('搜索订单编号'); $grid->filter(function (Grid\Filter $filter) { $filter->scope('unPay', '未付款')->unPay(); $filter->scope('paid', '待发货')->paid(); $filter->scope('delivered', '已发货')->delivered(); $filter->scope('signed', '已签收')->signed(); $filter->scope('completed', '已完成')->completed(); $filter->column(1 / 2, function (Grid\Filter $filter) { $filter->like('order_no', '订单编号'); // $filter->equal('shop_id', '所属店铺')->select(Shop::pluck('name', 'id')); $filter->equal('user_id', '提货用户')->select()->ajax(route('admin.user.users.ajax')); }); $filter->column(1 / 2, function (Grid\Filter $filter) { $filter->between('created_at', '下单时间')->datetime(); $filter->equal('state', '订单状态')->select(Order::STATUS_SAMPLE_MAP); // $filter->between('paid_at', '付款时间')->datetime(); // $filter->between('expired_at', '过期时间')->datetime(); }); }); $grid->disableActions(); $grid->model()->with(['shop', 'user.info']); $grid->column('order_no', '订单编号')->display(function () { return sprintf('%s', route('admin.mall.stock_orders.show', $this), $this->order_no); }); $grid->column('user.username', '提货用户') ->display(function () { return $this->user->username."({$this->user->info->nickname})"; }); $grid->column('qty', '提货数量') ->display(function () { return $this->items()->sum('qty'); }); $grid->column('areaCode.code', '提货码'); $grid->column('state', '订单状态') ->display(function () { return $this->state_text; }) ->label(); $grid->column('type', '订单类型')->using(Order::TYPE_MAP)->label(); $grid->column('created_at', '下单时间')->sortable(); $grid->disableExport(false); $grid->export(function ($export) { $export->column('order_no', function ($value, $original) { return strip_tags($value)."\n"; }); $export->column('type', function ($value, $original) { return strip_tags($value); }); $export->column('state', function ($value, $original) { return strip_tags($value); }); $export->except(['versions_count', 'paid_at', 'expired_at']); $export->filename($this->title.date("YmdHis")); }); return $grid; } /** * Notes : 订单详情 * * @Date : 2021/3/16 1:46 下午 * @Author : < Jason.C > * @param string $orderNo 订单的 order_no */ protected function detail(string $orderNo) { $order = Order::query()->firstWhere(['order_no' => $orderNo]); return view('mall::admin.stock_order.detail', compact('order')); } }