RecuperateController.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349
  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->column('status','状态')->display(function($status){
  91. if ($status == 1) {
  92. return '进行中';
  93. } else {
  94. return '已结束';
  95. }
  96. });
  97. $grid->price('价格');
  98. $grid->visit('天数');
  99. $grid->place('地点');
  100. $grid->list_order('排序');
  101. $grid->click('点击量');
  102. $grid->created_at('添加时间');
  103. //新增按钮
  104. $grid->disableCreateButton(false);
  105. //批量删除
  106. $grid->tools(function ($tools) {
  107. $tools->batch(function ($batch) {
  108. $batch->disableDelete(false);
  109. });
  110. });
  111. $grid->actions(function ($actions) {
  112. $actions->disableEdit(false);
  113. $actions->disableDelete(false);
  114. $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>');
  115. });
  116. $grid->filter(function ($filter) {
  117. $filter->disableIdFilter();
  118. $filter->like('title', '套餐标题');
  119. $date3 = date('Y-m-d', strtotime("-3 day"));
  120. $date7 = date('Y-m-d', strtotime("-7 day"));
  121. $date30 = date("Y-m-d", strtotime("-1 month"));
  122. $date180 = date("Y-m-d", strtotime("-6 month"));
  123. $date360 = date("Y-m-d", strtotime("-1 year"));
  124. $date_option = [
  125. '' => '不限',
  126. $date3 => '三天内',
  127. $date7 => '一周内',
  128. $date30 => '一月内',
  129. $date180 => '半年内',
  130. $date360 => '一年内',
  131. ];
  132. $filter->where(function ($query) {
  133. $query->where('created_at', '>=', "{$this->input}");
  134. }, '添加时间', 'created_at')->radio($date_option);
  135. });
  136. return $grid;
  137. }
  138. /**
  139. * Make a form builder.
  140. *
  141. * @return Form
  142. */
  143. protected function form()
  144. {
  145. $display_option = [
  146. 'on' => ['value' => 1, 'text' => '是', 'color' => 'success'],
  147. 'off' => ['value' => 0, 'text' => '否', 'color' => 'danger'],
  148. ];
  149. $form = new ValidateForm(new Recuperate());
  150. $category = array_column(RecuperateCategory::where('deleted_at', null)->select('id', 'name')->get()->toArray(), 'name', 'id');
  151. $form->select('r_c_id', '分类名称')->rules('required', ['required' => '分类名称为空。'])->options($category)->setMustMark();
  152. $form->text('title', '标题')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setWidth(4)->setMustMark();
  153. $form->color('tit_color', '标题颜色')->rules('required|regex:/^#[a-fA-F0-9]{6}$/', ['required' => '标题颜色不能为空。', 'regex' => '标题颜色格式不正确。'])->default('#000000');
  154. $form->switch('tit_b', '标题加粗')->states($display_option)->default(0)->setMustMark();
  155. $form->textarea('describe', '描述')->rules('required|max:1024', ['required' => '描述不能为空。', 'max' => '描述长度不能大于1024。'])->setWidth(8)->setMustMark();
  156. $form->number('price', '价格')->rules('required', ['required' => '价格不能为空。'])->setWidth(4)->setMustMark();
  157. $form->text('visit', '天数')->rules('required', ['required' => '天数不能为空。'])->setWidth(4)->setMustMark();
  158. $form->text('place', '地点')->rules('required', ['required' => '地点不能为空。'])->setWidth(4)->setMustMark();
  159. $form->datetime('travel_time', '出行时间')->rules('required', ['required' => '出行时间不能为空。'])->setWidth(4)->setMustMark();
  160. $form->image('small_img', '缩略图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', ['image' => '缩略图请选择图片文件。', 'mimes' => '请选择jpeg,bmp,png格式的缩略图上传。'])->setWidth(4);
  161. $form->multipleFile('img_list', '轮播图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', ['image' => '轮播图请选择图片文件。', 'mimes' => '请选择jpeg,bmp,png格式的缩略图上传。'])->setWidth(4)->removable();
  162. $form->editor('content', '内容')->rules('required', ['required' => '内容不能为空。'])->setMustMark();
  163. $form->switch('is_display', '是否显示')->states($display_option)->default('1')->setMustMark();
  164. $form->radio('status', '状态')->options([1=>'进行中', 2=>'结束' ])->default('1');
  165. $form->number('list_order', '排序')->min(0)->default(0)->rules('required', ['required' => '排序不能为空。'])->help('(数字越大越靠前)');
  166. $form->saved(function (Form $form) {
  167. //如果没有上传logo,判断是否
  168. $small_img = \Illuminate\Support\Facades\Request::input('small_img');
  169. if (!$form->model()->small_img && $small_img) {
  170. $form->model()->small_img = $small_img;
  171. $form->model()->save();
  172. }
  173. $img_list = \Illuminate\Support\Facades\Request::input('img_list');
  174. if (!$form->model()->img_list && $img_list) {
  175. $form->model()->img_list = $img_list;
  176. $form->model()->save();
  177. }
  178. });
  179. $form->footer(function ($footer) {
  180. $footer->disableViewCheck();
  181. $footer->disableEditingCheck();
  182. $footer->disableCreatingCheck();
  183. $footer->disableReset();
  184. });
  185. return $form;
  186. }
  187. protected function editForm($id)
  188. {
  189. $display_option = [
  190. 'on' => ['value' => 1, 'text' => '是', 'color' => 'success'],
  191. 'off' => ['value' => 0, 'text' => '否', 'color' => 'danger'],
  192. ];
  193. $category = array_column(RecuperateCategory::where('deleted_at', null)->select('id', 'name')->get()->toArray(), 'name', 'id');
  194. $form = new ValidateForm(new Recuperate);
  195. $form->select('r_c_id', '分类名称')->rules('required', ['required' => '分类名称为空。'])->options($category)->setMustMark();
  196. $form->text('title', '标题')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setWidth(4)->setMustMark();
  197. $form->color('tit_color', '标题颜色')->rules('required|regex:/^#[a-fA-F0-9]{6}$/', ['required' => '标题颜色不能为空。', 'regex' => '标题颜色格式不正确。'])->default('#000000');
  198. $form->switch('tit_b', '标题加粗')->states($display_option)->default(0)->setMustMark();
  199. $form->textarea('describe', '描述')->rules('required|max:1024', ['required' => '描述不能为空。', 'max' => '描述长度不能大于1024。'])->setWidth(8)->setMustMark();
  200. $form->number('price', '价格')->rules('required', ['required' => '价格不能为空。'])->setWidth(4)->setMustMark();
  201. $form->text('visit', '天数')->rules('required', ['required' => '天数不能为空。'])->setWidth(4)->setMustMark();
  202. $form->text('place', '地点')->rules('required', ['required' => '地点不能为空。'])->setWidth(4)->setMustMark();
  203. $form->datetime('travel_time', '出行时间')->rules('required', ['required' => '出行时间不能为空。'])->setWidth(4)->setMustMark();
  204. $form->image('small_img', '缩略图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', ['image' => '缩略图请选择图片文件。', 'mimes' => '请选择jpeg,bmp,png格式的缩略图上传。'])->setWidth(4);
  205. $form->multipleFile('img_list', '轮播图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', ['image' => '轮播图请选择图片文件。', 'mimes' => '请选择jpeg,bmp,png格式的缩略图上传。'])->setWidth(4)->removable();
  206. $form->editor('content', '内容')->rules('required', ['required' => '内容不能为空。'])->setMustMark();
  207. $form->switch('is_display', '是否显示')->states($display_option)->default('1')->setMustMark();
  208. $form->radio('status', '状态')->options([1=>'进行中', 2=>'结束' ])->default('1')->setMustMark();
  209. $form->number('list_order', '排序')->min(0)->default(0)->rules('required', ['required' => '排序不能为空。'])->help('(数字越大越靠前)');
  210. $form->saved(function (Form $form) {
  211. //如果没有上传logo,判断是否
  212. $small_img = \Illuminate\Support\Facades\Request::input('small_img');
  213. if (!$form->model()->small_img && $small_img) {
  214. $form->model()->small_img = $small_img;
  215. $form->model()->save();
  216. }
  217. $img_list = \Illuminate\Support\Facades\Request::input('img_list');
  218. if (!$form->model()->img_list && $img_list) {
  219. $form->model()->img_list = $img_list;
  220. $form->model()->save();
  221. }
  222. });
  223. $form->footer(function ($footer) {
  224. $footer->disableViewCheck();
  225. $footer->disableEditingCheck();
  226. $footer->disableCreatingCheck();
  227. $footer->disableReset();
  228. });
  229. $form->tools(function (Form\Tools $tools) {
  230. $tools->disableDelete();
  231. $tools->disableView();
  232. });
  233. return $form;
  234. }
  235. public function update($id)
  236. {
  237. return $this->editForm($id)->update($id);
  238. }
  239. public function destroy($id)
  240. {
  241. //是否存在报名列表
  242. $ids = explode(',', $id);
  243. $check = RecuperateApply::whereIn('recuperate_id', $ids)->count();
  244. if ($check > 0) {
  245. return response()->json([
  246. 'status' => false,
  247. 'message' => '存在报名信息的人才活动不允许删除!',
  248. ]);
  249. }
  250. if ($this->form()->destroy($id)) {
  251. $data = [
  252. 'status' => true,
  253. 'message' => trans('admin.delete_succeeded'),
  254. ];
  255. } else {
  256. $data = [
  257. 'status' => false,
  258. 'message' => trans('admin.delete_failed'),
  259. ];
  260. }
  261. return response()->json($data);
  262. }
  263. /**
  264. * 导出报名列表
  265. */
  266. public function exportApply(Request $request)
  267. {
  268. //状态列表
  269. $level_arr = [
  270. '',
  271. '第一层次',
  272. '第二层次',
  273. '第三层次',
  274. '第四层次',
  275. '第五层次',
  276. '第六层次',
  277. '第七层次',
  278. ];
  279. $status_arr = [
  280. '待审核',
  281. '审核通过',
  282. '审核不通过',
  283. '取消活动',
  284. ];
  285. //获取数据
  286. $id = $request->id;
  287. $data = [];
  288. $list = RecuperateApply::where('recuperate_id', '=', $id)->get();
  289. //数据处理
  290. foreach ($list as $key => $value) {
  291. $data[$key]['user_name'] = $value->user_name;
  292. $data[$key]['user_idcard'] = $value->user_idcard;
  293. $data[$key]['mobile'] = $value->mobile;
  294. $data[$key]['wechat'] = $value->wechat;
  295. $data[$key]['company_name'] = $value->company_name;
  296. $data[$key]['level'] = $level_arr[$value->level];
  297. $data[$key]['validate_time'] = $value->validate_time;
  298. /*$data[$key]['condition'] = $value->condition;
  299. $data[$key]['tax'] = $value->tax;
  300. $data[$key]['salary'] = $value->salary;*/
  301. $data[$key]['created_at'] = $value->created_at;
  302. $data[$key]['status'] = $status_arr[$value->status];
  303. $data[$key]['reason'] = $value->reason;
  304. }
  305. //导出excel
  306. $info = Recuperate::where('id', $id)->first()->toArray();
  307. $export = new RecuperateExport($info['title'] . '报名列表');
  308. $c = new Collection([
  309. 'list' => $data,
  310. 'title' => $info['title'],
  311. ]);
  312. $export->setCustomerData($c)->export();//这里不需要return
  313. }
  314. }