header(admin_trans( 'admin.products_list')) ->description(admin_trans('admin.all')) ->description('all') ->breadcrumb(['text'=>'Product Management','url'=>'']) ->body($this->grid()); } /** * Edit interface. * * @param mixed $id * @param Content $content * @return Content */ public function edit($id, Content $content) { return $content ->translation($this->translation()) ->title(admin_trans('admin.product')) ->description($this->description()['edit'] ?? trans('admin.edit')) ->body($this->form()->edit($id)); } /** * Create interface. * * @param Content $content * @return Content */ public function create(Content $content) { return $content ->translation($this->translation()) ->title(admin_trans('admin.product')) ->description($this->description()['create'] ?? trans('admin.create')) ->body($this->form()); } /** * Make a grid builder. * * @return Grid */ protected function grid() { return Grid::make(DistProduct::with(['distProductCategory','images']), function (Grid $grid) { $grid->column('id','ID')->sortable(); $grid->column('title'); $grid->column('sku'); $grid->column('dist_product_category.name',admin_trans_label('category_name')); $grid->column('issuance_date'); $grid->column('images')->display(function ($images) { $images = $images->toArray(); $dataImages = array_column($images, 'image_url'); return CommonHelper::displayImage($dataImages,150); }); $grid->column('order')->orderable(); $grid->column('is_pinned')->switch(); $grid->column('enabled')->switch(); $grid->column('created_at'); $grid->column('updated_at')->sortable(); // 筛选 $grid->filter(function (Grid\Filter $filter) { $filter->equal('sku'); $filter->like('title'); $filter->equal('category_id','Category')->select(DistProductCategory::selectOptions()); $filter->equal('enabled', 'enabled')->select(config('dictionary.enabled')); }); //排序 $grid->model()->orderBy("is_pinned",'desc')->orderBy("order",'desc'); }); } /** * Make a show builder. * * @param mixed $id * * @return Show */ protected function detail($id) { return Show::make($id, DistProduct::with(['distProductCategory','images']), function (Show $show) { $show->field('id'); $show->field('title'); $show->field('keywords'); $show->field('description'); $show->field('sku'); $show->field('dist_product_category.name',admin_trans_label('category_name')); $show->field('issuance_date'); $show->field('parameters')->as(function ($items) { if (is_array($items)) { // 创建表格的表头 $table = '
'.admin_trans_field('key').' | '.admin_trans_field('value').' |
---|---|
' . $item['key'] . ' | '; // 商品名称 $table .= '' . $item['value'] . ' | '; // 数量 $table .= '