ImportProductController.php 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  1. <?php
  2. namespace App\Admin\Controllers;
  3. use App\Admin\Actions\Grid\RpcAlbumImport;
  4. use App\Admin\Forms\RpcAlbumImportForm;
  5. use App\Admin\Repositories\BaseProductCategory;
  6. use App\Admin\Repositories\RpcAlbum;
  7. use App\Admin\Repositories\RpcAlbumFolder;
  8. use App\Distributor\Actions\Extensions\DistProductImportForm;
  9. use App\Distributor\Repositories\BaseProduct;
  10. use App\Libraries\CommonHelper;
  11. use Dcat\Admin\Admin;
  12. use Dcat\Admin\Grid;
  13. use Dcat\Admin\Http\Controllers\AdminController;
  14. use Dcat\Admin\Layout\Content;
  15. use Dcat\Admin\Show;
  16. class ImportProductController extends AdminController
  17. {
  18. public function title()
  19. {
  20. return admin_trans( 'admin.product_import');
  21. }
  22. /**
  23. * page index
  24. */
  25. public function index(Content $content)
  26. {
  27. return $content
  28. ->header(admin_trans( 'admin.product_import'))
  29. ->description('<span style="color: red; font-weight: bold;">'.admin_trans_label('select_products_to_import').'</span>')
  30. ->breadcrumb(['text'=>'list','url'=>''])
  31. ->body($this->grid());
  32. }
  33. //屏蔽删除
  34. public function destroy($id)
  35. {
  36. abort(404);
  37. }
  38. //屏蔽创建
  39. public function create(Content $content)
  40. {
  41. abort(404);
  42. }
  43. //屏蔽编辑
  44. public function edit($id, Content $content)
  45. {
  46. abort(404);
  47. }
  48. /**
  49. * Make a grid builder.
  50. *
  51. * @return Grid
  52. */
  53. protected function grid()
  54. {
  55. return Grid::make(new RpcAlbum(), function (Grid $grid) {
  56. $lang = config('app.locale');//当前语言
  57. $grid->view('admin.grid.table');
  58. $grid->column('id')->display(function () {
  59. return $this->_index+1;
  60. })->width('8%');
  61. $grid->column('cover')->display(function ($images) {
  62. $images = json_decode($images);
  63. // 限制最多显示2个缩略图
  64. $dataImages = array_slice($images, 0, 1);
  65. return CommonHelper::displayImage($dataImages,100,1024,2);
  66. });
  67. if ($lang == 'en') {
  68. $grid->column('title_en');
  69. } else {
  70. $grid->column('title');
  71. }
  72. $grid->column('model');
  73. $grid->column('missing_content')->display(function ($missing_content) {
  74. $missing_content = [];
  75. if ($this->cover == '[]') {$missing_content[] = '主图';}
  76. if ($this->en_detail == '[]') {$missing_content[] = '英文详情';}
  77. if ($this->cn_detail == '[]') {$missing_content[] = '中文详情';}
  78. if ($this->video == '[]') {$missing_content[] = '视频';}
  79. if ($this->poster == '[]') {$missing_content[] = '海报';}
  80. if ($this->cert == '[]') {$missing_content[] = '证书';}
  81. if ($this->pdf == '[]') {$missing_content[] = 'PDF';}
  82. return implode(' / ', $missing_content);
  83. });
  84. $grid->column('created_at')->sortable();
  85. $grid->column('updated_at')->sortable();
  86. // 筛选
  87. $grid->filter(function (Grid\Filter $filter) {
  88. $filter->panel();
  89. $filter->expand();
  90. $filter->equal('model')->width(2);
  91. $lang = config('app.locale');//当前语言
  92. $filter->equal('folder_id',admin_trans_label('product_category'))->select(RpcAlbumFolder::selectOptions($lang))->width(3);
  93. });
  94. // 删除新增按钮
  95. $grid->disableCreateButton();
  96. //$grid->disableViewButton();
  97. $grid->disableEditButton();
  98. $grid->disableDeleteButton();
  99. $grid->disableBatchDelete();
  100. // 添加批量复制操作
  101. $grid->batchActions(function ($batch) {
  102. //$batch->add(new BatchCopy()); 只能2选1
  103. });
  104. $grid->tools([
  105. new RpcAlbumImport(),
  106. ]);
  107. $grid->model()->where('enabled',1)->orderBy("order",'desc')->orderBy("created_at",'desc');
  108. });
  109. }
  110. /**
  111. * Make a show builder.
  112. *
  113. * @param mixed $id
  114. *
  115. * @return Show
  116. */
  117. protected function detail($id)
  118. {
  119. return Show::make($id, new RpcAlbum(), function (Show $show) {
  120. $lang = config('app.locale');//当前语言
  121. if ($lang == 'en') {
  122. $show->field('title_en');
  123. } else {
  124. $show->field('title');
  125. }
  126. $show->field('model');
  127. $show->field('parameters',admin_trans_label('attribute'))->as(function ($items) {
  128. $items = json_decode($items);
  129. if (is_array($items)) {
  130. // 创建表格的表头
  131. $table = '<table class="table table-bordered table-condensed">';
  132. // 遍历数组并将数据填充到表格中
  133. foreach ($items as $item) {
  134. $item = (array)$item;
  135. $table .= '<tr>';
  136. $table .= '<td style="vertical-align: middle !important;width: 20%">' . $item['key'] . '</td>'; // 商品名称
  137. $table .= '<td style="vertical-align: middle !important;">' . $item['value'] . '</td>'; // 数量
  138. $table .= '</tr>';
  139. }
  140. $table .= '</table>';
  141. return $table;
  142. }
  143. return ''; // 当没有数组数据时
  144. })->unescape();
  145. $show->field('cover')->as(function ($images) {
  146. $images = json_decode($images);
  147. return CommonHelper::displayImage($images,150,1024,2);
  148. })->unescape();
  149. $show->field('en_detail')->as(function ($images) {
  150. $images = json_decode($images);
  151. $html = '<div style="text-align: center">';
  152. foreach ($images as $key => $image) {
  153. $url = CommonHelper::albumUrl($image);
  154. $html .= '<img src="' . $url . '" style="max-width:90%;margin-bottom:10px">';
  155. }
  156. $html .= '</div>';
  157. return $html;
  158. })->unescape();
  159. $show->field('cn_detail')->as(function ($images) {
  160. $images = json_decode($images);
  161. $html = '<div style="text-align: center">';
  162. foreach ($images as $key => $image) {
  163. $url = CommonHelper::albumUrl($image);
  164. $html .= '<img src="' . $url . '" style="max-width:90%;margin-bottom:10px">';
  165. }
  166. $html .= '</div>';
  167. return $html;
  168. })->unescape();
  169. $show->field('video')->as(function ($items) {
  170. $items = json_decode($items);
  171. return CommonHelper::displayVideo($items,'cover','video_src','150');
  172. })->unescape();
  173. $show->field('poster')->as(function ($images) {
  174. $images = json_decode($images);
  175. return CommonHelper::displayImage($images,150,1024,2);
  176. })->unescape();
  177. $show->field('cert')->as(function ($images) {
  178. $images = json_decode($images);
  179. return CommonHelper::displayImage($images,150,1024,2);
  180. })->unescape();
  181. $show->field('cert')->as(function ($images) {
  182. $images = json_decode($images);
  183. return CommonHelper::displayImage($images,150,1024,2);
  184. })->unescape();
  185. $show->field('pdf')->as(function ($items) {
  186. $items = json_decode($items);
  187. if (is_array($items)) {
  188. // 创建表格的表头
  189. $table = '<table class="table table-bordered table-condensed">';
  190. // 遍历数组并将数据填充到表格中
  191. foreach ($items as $item) {
  192. $table .= '<tr>';
  193. $table .= '<td style="vertical-align: middle !important;width: 20%">' . $item->pdf_title . '</td>'; // 商品名称
  194. $table .= '<td style="vertical-align: middle !important;"><a target="_blank" href="' . CommonHelper::albumUrl($item->pdf_src). '">查看</a></td>'; // 数量
  195. $table .= '</tr>';
  196. }
  197. $table .= '</table>';
  198. return $table;
  199. }
  200. return ''; // 当没有数组数据时
  201. })->unescape();
  202. // 禁用操作
  203. $show->disableEditButton();
  204. $show->disableDeleteButton();
  205. });
  206. }
  207. }