123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189 |
- <?php
- namespace App\Distributor\Controllers;
- use App\Distributor\Actions\Extensions\DistProductImportForm;
- use App\Distributor\Repositories\BaseProduct;
- use App\Admin\Repositories\BaseProductCategory;
- use App\Distributor\Actions\BatchCopy;
- use App\Distributor\Repositories\DistProductCategory;
- use App\Libraries\CommonHelper;
- use Dcat\Admin\Form;
- use Dcat\Admin\Grid;
- use Dcat\Admin\Show;
- use Dcat\Admin\Http\Controllers\AdminController;
- use Dcat\Admin\Layout\Content;
- use Dcat\Admin\Admin;
- class ImportProductController extends AdminDistController
- {
-
- public function index(Content $content)
- {
- return $content
- ->header('Product Import')
- ->description('<span style="color: red; font-weight: bold;">'.admin_trans_label('select_products_to_import').'</span>')
- ->breadcrumb(['text'=>'list','url'=>''])
- ->body($this->grid());
- }
-
- public function destroy($id)
- {
- abort(404);
- }
-
- public function create(Content $content)
- {
- abort(404);
- }
-
- public function edit($id, Content $content)
- {
- abort(404);
- }
-
- protected function grid()
- {
- return Grid::make(BaseProduct::with(['baseProductCategory','images']), function (Grid $grid) {
- $grid->column('id')->sortable();
- $grid->column('title');
- $grid->column('sku');
- $grid->column('base_product_category.name',admin_trans_label('category_name'));
- $grid->column('keywords');
- $grid->column('description');
- $grid->column('issuance_date');
-
- $grid->filter(function (Grid\Filter $filter) {
- $filter->panel();
- $filter->expand();
- $filter->equal('sku')->width(2);
- $filter->like('title')->width(2);
- $filter->equal('category_id',admin_trans_label('category'))->select(BaseProductCategory::selectOptions())->width(2);
-
- });
-
-
-
-
-
-
- $grid->disableCreateButton();
-
- $grid->disableEditButton();
- $grid->disableDeleteButton();
- $grid->disableBatchDelete();
-
- $grid->batchActions(function ($batch) {
-
- });
- $grid->tools([
- new DistProductImportForm(),
- ]);
- $grid->model()->where('enabled',1)->orderBy("is_pinned",'desc')->orderBy("order",'desc');
- });
- }
-
- protected function detail($id)
- {
- return Show::make($id, BaseProduct::with(['baseProductCategory','images']), function (Show $show) {
- $show->field('id');
- $show->field('title');
- $show->field('sku');
- $show->field('base_product_category.name',admin_trans_label('category_name'));
- $show->field('keywords');
- $show->field('description');
- $show->field('issuance_date');
- $show->field('parameters')->as(function ($items) {
- if (is_array($items)) {
-
- $table = '<table class="table">';
- $table .= '<tr><th>key</th><th>value</th></tr>';
-
- foreach ($items as $item) {
- $table .= '<tr>';
- $table .= '<td>' . $item['key'] . '</td>';
- $table .= '<td>' . $item['value'] . '</td>';
- $table .= '</tr>';
- }
- $table .= '</table>';
- return $table;
- }
- return '';
- })->unescape();
- $show->field('images')->as(function ($images) {
-
- $dataImages = array_column($images, 'image_url');
- return CommonHelper::displayImage($dataImages,150);
- })->unescape();
- $show->field('content')->unescape();
- $show->field('seo_title');
- $show->field('seo_keywords');
- $show->field('seo_description');
-
-
-
- $show->disableEditButton();
- $show->disableDeleteButton();
- });
- }
-
- }
|