'待付款', 1 => '待发货', 2 => '发货中', 3 => '已发货', 9 => '已完成', 10 => '已取消', ]; public $statusColor = [ 0 => 'primary', 1 => 'warning', 2 => 'danger', 3 => 'success', 9 => 'success', 10 => '#b3b9bf', ]; protected $translation = 'store-order'; protected function grid() { $grid = new Grid(Order::with(['user', 'inviter', 'store'])); $user = Admin::user(); $canAdmin = $this->canAdmin(); if (!$canAdmin) { $stores = $user->stores->pluck('id'); $grid->model()->whereIn('store_id', $stores); } $grid->model()->whereNotNull('store_id')->orderBy('created_at', 'desc'); $grid->column('store.title', '门店'); $grid->column('sn')->copyable(); $grid->column('user.phone')->copyable(); $grid->column('inviter.phone')->copyable(); $grid->column('total_amount')->display(function ($value) { return bcdiv($value, 100, 2); })->prepend('¥'); $grid->column('market_price')->display(function ($value) { return bcdiv($value, 100, 2); })->prepend('¥'); $grid->column('cost_price')->display(function ($value) { return bcdiv($value, 100, 2); })->prepend('¥'); $grid->column('sales_value'); $grid->column('order_status')->using($this->statusMap)->dot($this->statusColor); $grid->column('pay_way')->display(function ($v) { return $v?->mallText(); })->circleDot(PayWay::colors()); $grid->column('pay_at'); $grid->column('created_at'); $grid->showViewButton($user->can('dcat.admin.store.order.show')); $grid->filter(function (Grid\Filter $filter) { $filter->panel(); $filter->equal('store_id', '门店')->select('api/store')->width(3); $filter->like('sn')->width(3); $filter->like('user.phone')->width(3); $filter->like('inviter.phone')->width(3); $filter->equal('pay_way')->select([ PayWay::WxpayMiniProgram->value => PayWay::WxpayMiniProgram->text(), PayWay::Offline->value => PayWay::Offline->text(), ])->width(3); $filter->where('order_status', function ($q) { switch ($this->input) { case OrderStatus::PENDING: $q->where('status', Order::STATUS_PENDING); break; case OrderStatus::WAIT_SHIPPING: $q->where('status', Order::STATUS_PAID)->where('shipping_state', Order::SHIPPING_STATE_PENDING); break; case OrderStatus::SHIPPING: $q->where('status', Order::STATUS_PAID)->where('shipping_state', Order::SHIPPING_STATE_PROCESSING); break; case OrderStatus::SHIPPED: $q->where('status', Order::STATUS_PAID)->where('shipping_state', Order::SHIPPING_STATE_PROCESSED); break; case OrderStatus::COMPLETED: $q->where('status', Order::STATUS_COMPLETED); break; case OrderStatus::CANCELLED: $q->where('status', Order::STATUS_CANCELLED); break; } })->select([ OrderStatus::PENDING => '待付款', OrderStatus::WAIT_SHIPPING => '待发货', OrderStatus::SHIPPING => '发货中', OrderStatus::SHIPPED => '已发货', OrderStatus::COMPLETED => '已完成', OrderStatus::CANCELLED => '已取消' ])->width(3); $filter->between('created_at')->dateTime()->width(6); }); $grid->footer(function ($collection) use ($grid) { $query = Order::query(); $grid->model()->getQueries()->unique()->each(function ($value) use (&$query) { if (in_array($value['method'], ['paginate', 'get', 'orderBy', 'orderByDesc'], true)) { return; } $query = call_user_func_array([$query, $value['method']], $value['arguments'] ?? []); }); $count = $query->count(); $total_amount = number_format($query->sum('total_amount') / 100); $market_price = number_format($query->sum('market_price') / 100); $cost_price = number_format($query->sum('cost_price') / 100); $sales_value = number_format($query->sum('sales_value')); return <<