RecuperateController.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  1. <?php
  2. namespace App\Admin\Controllers\Content;
  3. use App\Admin\Exports\Content\RecuperateExport;
  4. use App\Admin\Extensions\Form\ValidateForm;
  5. use App\Http\Controllers\Controller;
  6. use App\Models\Recuperate;
  7. use App\Models\RecuperateApply;
  8. use App\Models\RecuperateCategory;
  9. use Encore\Admin\Controllers\HasResourceActions;
  10. use Encore\Admin\Facades\Admin as userAdmin;
  11. use Encore\Admin\Form;
  12. use Encore\Admin\Grid;
  13. use Encore\Admin\Layout\Content;
  14. use Illuminate\Http\Request;
  15. use Illuminate\Support\Collection;
  16. class RecuperateController extends Controller
  17. {
  18. use HasResourceActions;
  19. /**
  20. * Index interface.
  21. *
  22. * @param Content $content
  23. * @return Content
  24. */
  25. public function index(Content $content)
  26. {
  27. return $content
  28. ->header('人才活动列表')
  29. ->description(' ')
  30. ->body(view('admin.content.recuperate')->with(['grid' => $this->grid()]));
  31. }
  32. /**
  33. * Edit interface.
  34. *
  35. * @param mixed $id
  36. * @param Content $content
  37. * @return Content
  38. */
  39. public function edit($id, Content $content)
  40. {
  41. return $content
  42. ->header('人才活动')
  43. ->description(' ')
  44. ->body($this->editForm($id)->edit($id));
  45. }
  46. /**
  47. * Create interface.
  48. *
  49. * @param Content $content
  50. * @return Content
  51. */
  52. public function create(Content $content)
  53. {
  54. return $content
  55. ->header('人才活动')
  56. ->description(' ')
  57. ->body($this->form());
  58. }
  59. public function show()
  60. {
  61. return redirect("/ST3IXxKlOa4eGEv0eTw0CfORI9444Mgj/content/recuperate/index");
  62. }
  63. /**
  64. * Make a grid builder.
  65. *
  66. * @return Grid
  67. */
  68. protected function grid()
  69. {
  70. $grid = new Grid(new Recuperate());
  71. $grid->model()->orderBy('created_at', 'DESC');
  72. $grid->id('ID');
  73. $grid->column('recuperate_category.name','分类');
  74. $grid->column('标题')->display(function () {
  75. $style = "color:" . $this->tit_color . ';';
  76. if ($this->tit_b == '1') {
  77. $style .= 'font-weight:bold;';
  78. }
  79. return '<span style="' . $style . '">' . $this->title . '</span>';
  80. })->width(200);
  81. $grid->small_img('缩略图')->display(function () {
  82. if ($this->small_img) {
  83. return '<span class="vtip" title="<img src=\'' . upload_asset($this->small_img) . '\' height=120>">
  84. <img class="avatar small" src="' . upload_asset($this->small_img) . '" align="absmiddle" style="width: 22px;height: 22px;">
  85. </span>';
  86. } else {
  87. return '';
  88. }
  89. });
  90. $grid->price('价格');
  91. $grid->visit('天数');
  92. $grid->place('地点');
  93. $grid->list_order('排序');
  94. $grid->click('点击量');
  95. $grid->created_at('添加时间');
  96. //新增按钮
  97. $grid->disableCreateButton(false);
  98. //批量删除
  99. $grid->tools(function ($tools) {
  100. $tools->batch(function ($batch) {
  101. $batch->disableDelete(false);
  102. });
  103. });
  104. $grid->actions(function ($actions) {
  105. $actions->disableEdit(false);
  106. $actions->disableDelete(false);
  107. $actions->append('<a href="' . route('recuperate.export_apply', ['id' => $actions->row['id']]) . '" target="_blank"><button class="btn btn-primary btn-xs business" title="导出报名列表" >导出报名列表</button></a>');
  108. });
  109. $grid->filter(function ($filter) {
  110. $filter->disableIdFilter();
  111. $filter->like('title', '套餐标题');
  112. $date3 = date('Y-m-d', strtotime("-3 day"));
  113. $date7 = date('Y-m-d', strtotime("-7 day"));
  114. $date30 = date("Y-m-d", strtotime("-1 month"));
  115. $date180 = date("Y-m-d", strtotime("-6 month"));
  116. $date360 = date("Y-m-d", strtotime("-1 year"));
  117. $date_option = [
  118. '' => '不限',
  119. $date3 => '三天内',
  120. $date7 => '一周内',
  121. $date30 => '一月内',
  122. $date180 => '半年内',
  123. $date360 => '一年内',
  124. ];
  125. $filter->where(function ($query) {
  126. $query->where('created_at', '>=', "{$this->input}");
  127. }, '添加时间', 'created_at')->radio($date_option);
  128. });
  129. return $grid;
  130. }
  131. /**
  132. * Make a form builder.
  133. *
  134. * @return Form
  135. */
  136. protected function form()
  137. {
  138. $display_option = [
  139. 'on' => ['value' => 1, 'text' => '是', 'color' => 'success'],
  140. 'off' => ['value' => 0, 'text' => '否', 'color' => 'danger'],
  141. ];
  142. $form = new ValidateForm(new Recuperate());
  143. $category = array_column(RecuperateCategory::where('deleted_at',null)->select('id','name')->get()->toArray(), 'name', 'id');
  144. $form->select('r_c_id', '分类名称')->rules('required', ['required' => '分类名称为空。'])->options($category)->setMustMark();
  145. $form->text('title', '标题')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setWidth(4)->setMustMark();
  146. $form->color('tit_color', '标题颜色')->rules('required|regex:/^#[a-fA-F0-9]{6}$/', ['required' => '标题颜色不能为空。', 'regex' => '标题颜色格式不正确。'])->default('#000000');
  147. $form->switch('tit_b', '标题加粗')->states($display_option)->default(0)->setMustMark();
  148. $form->textarea('describe', '描述')->rules('required|max:1024', ['required' => '描述不能为空。', 'max' => '描述长度不能大于1024。'])->setWidth(8)->setMustMark();
  149. $form->number('price', '价格')->rules('required', ['required' => '价格不能为空。'])->setWidth(4)->setMustMark();
  150. $form->text('visit', '天数')->rules('required', ['required' => '天数不能为空。'])->setWidth(4)->setMustMark();
  151. $form->text('place', '地点')->rules('required', ['required' => '地点不能为空。'])->setWidth(4)->setMustMark();
  152. $form->datetime('travel_time', '出行时间')->rules('required', ['required' => '出行时间不能为空。'])->setWidth(4)->setMustMark();
  153. $form->image('small_img', '缩略图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', ['image' => '缩略图请选择图片文件。', 'mimes' => '请选择jpeg,bmp,png格式的缩略图上传。'])->setWidth(4);
  154. $form->multipleFile('img_list', '轮播图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', ['image' => '轮播图请选择图片文件。', 'mimes' => '请选择jpeg,bmp,png格式的缩略图上传。'])->setWidth(4)->removable();
  155. $form->editor('content', '内容')->rules('required', ['required' => '内容不能为空。'])->setMustMark();
  156. $form->switch('is_display', '是否显示')->states($display_option)->default('1')->setMustMark();
  157. $form->number('list_order', '排序')->min(0)->default(0)->rules('required', ['required' => '排序不能为空。'])->help('(数字越大越靠前)');
  158. $form->saved(function (Form $form) {
  159. //如果没有上传logo,判断是否
  160. $small_img = \Illuminate\Support\Facades\Request::input('small_img');
  161. if (!$form->model()->small_img && $small_img) {
  162. $form->model()->small_img = $small_img;
  163. $form->model()->save();
  164. }
  165. $img_list = \Illuminate\Support\Facades\Request::input('img_list');
  166. if (!$form->model()->img_list && $img_list) {
  167. $form->model()->img_list = $img_list;
  168. $form->model()->save();
  169. }
  170. });
  171. $form->footer(function ($footer) {
  172. $footer->disableViewCheck();
  173. $footer->disableEditingCheck();
  174. $footer->disableCreatingCheck();
  175. $footer->disableReset();
  176. });
  177. return $form;
  178. }
  179. protected function editForm($id)
  180. {
  181. $display_option = [
  182. 'on' => ['value' => 1, 'text' => '是', 'color' => 'success'],
  183. 'off' => ['value' => 0, 'text' => '否', 'color' => 'danger'],
  184. ];
  185. $category = array_column(RecuperateCategory::where('deleted_at',null)->select('id','name')->get()->toArray(), 'name', 'id');
  186. $form = new ValidateForm(new Recuperate);
  187. $form->select('r_c_id', '分类名称')->rules('required', ['required' => '分类名称为空。'])->options($category)->setMustMark();
  188. $form->text('title', '标题')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setWidth(4)->setMustMark();
  189. $form->color('tit_color', '标题颜色')->rules('required|regex:/^#[a-fA-F0-9]{6}$/', ['required' => '标题颜色不能为空。', 'regex' => '标题颜色格式不正确。'])->default('#000000');
  190. $form->switch('tit_b', '标题加粗')->states($display_option)->default(0)->setMustMark();
  191. $form->textarea('describe', '描述')->rules('required|max:1024', ['required' => '描述不能为空。', 'max' => '描述长度不能大于1024。'])->setWidth(8)->setMustMark();
  192. $form->number('price', '价格')->rules('required', ['required' => '价格不能为空。'])->setWidth(4)->setMustMark();
  193. $form->text('visit', '天数')->rules('required', ['required' => '天数不能为空。'])->setWidth(4)->setMustMark();
  194. $form->text('place', '地点')->rules('required', ['required' => '地点不能为空。'])->setWidth(4)->setMustMark();
  195. $form->datetime('travel_time', '出行时间')->rules('required', ['required' => '出行时间不能为空。'])->setWidth(4)->setMustMark();
  196. $form->image('small_img', '缩略图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', ['image' => '缩略图请选择图片文件。', 'mimes' => '请选择jpeg,bmp,png格式的缩略图上传。'])->setWidth(4);
  197. $form->multipleFile('img_list', '轮播图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', ['image' => '轮播图请选择图片文件。', 'mimes' => '请选择jpeg,bmp,png格式的缩略图上传。'])->setWidth(4)->removable();
  198. $form->editor('content', '内容')->rules('required', ['required' => '内容不能为空。'])->setMustMark();
  199. $form->switch('is_display', '是否显示')->states($display_option)->default('1')->setMustMark();
  200. $form->number('list_order', '排序')->min(0)->default(0)->rules('required', ['required' => '排序不能为空。'])->help('(数字越大越靠前)');
  201. $form->saved(function (Form $form) {
  202. //如果没有上传logo,判断是否
  203. $small_img = \Illuminate\Support\Facades\Request::input('small_img');
  204. if (!$form->model()->small_img && $small_img) {
  205. $form->model()->small_img = $small_img;
  206. $form->model()->save();
  207. }
  208. $img_list = \Illuminate\Support\Facades\Request::input('img_list');
  209. if (!$form->model()->img_list && $img_list) {
  210. $form->model()->img_list = $img_list;
  211. $form->model()->save();
  212. }
  213. });
  214. $form->footer(function ($footer) {
  215. $footer->disableViewCheck();
  216. $footer->disableEditingCheck();
  217. $footer->disableCreatingCheck();
  218. $footer->disableReset();
  219. });
  220. $form->tools(function (Form\Tools $tools) {
  221. $tools->disableDelete();
  222. $tools->disableView();
  223. });
  224. return $form;
  225. }
  226. public function update($id)
  227. {
  228. return $this->editForm($id)->update($id);
  229. }
  230. public function destroy($id)
  231. {
  232. //是否存在报名列表
  233. $ids = explode(',', $id);
  234. $check = RecuperateApply::whereIn('recuperate_id', $ids)->count();
  235. if ($check > 0) {
  236. return response()->json([
  237. 'status' => false,
  238. 'message' => '存在报名信息的人才活动不允许删除!',
  239. ]);
  240. }
  241. if ($this->form()->destroy($id)) {
  242. $data = [
  243. 'status' => true,
  244. 'message' => trans('admin.delete_succeeded'),
  245. ];
  246. } else {
  247. $data = [
  248. 'status' => false,
  249. 'message' => trans('admin.delete_failed'),
  250. ];
  251. }
  252. return response()->json($data);
  253. }
  254. /**
  255. * 导出报名列表
  256. */
  257. public function exportApply(Request $request)
  258. {
  259. //状态列表
  260. $level_arr = [
  261. '',
  262. '第一层次',
  263. '第二层次',
  264. '第三层次',
  265. '第四层次',
  266. '第五层次',
  267. '第六层次',
  268. '第七层次',
  269. ];
  270. $status_arr = [
  271. '待审核',
  272. '审核通过',
  273. '审核不通过',
  274. '取消活动',
  275. ];
  276. //获取数据
  277. $id = $request->id;
  278. $data = [];
  279. $list = RecuperateApply::where('recuperate_id', '=', $id)->get();
  280. //数据处理
  281. foreach ($list as $key => $value) {
  282. $data[$key]['user_name'] = $value->user_name;
  283. $data[$key]['user_idcard'] = $value->user_idcard;
  284. $data[$key]['mobile'] = $value->mobile;
  285. $data[$key]['wechat'] = $value->wechat;
  286. $data[$key]['company_name'] = $value->company_name;
  287. $data[$key]['level'] = $level_arr[$value->level];
  288. $data[$key]['condition'] = $value->condition;
  289. $data[$key]['tax'] = $value->tax;
  290. $data[$key]['salary'] = $value->salary;
  291. $data[$key]['created_at'] = $value->created_at;
  292. $data[$key]['status'] = $status_arr[$value->status];
  293. $data[$key]['reason'] = $value->reason;
  294. }
  295. //导出excel
  296. $info = Recuperate::where('id', $id)->first()->toArray();
  297. $export = new RecuperateExport($info['title'] . '报名列表');
  298. $c = new Collection([
  299. 'list' => $data,
  300. 'title' => $info['title'],
  301. ]);
  302. $export->setCustomerData($c)->export();//这里不需要return
  303. }
  304. }