BuyHouseBlacklistController.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. <?php
  2. namespace App\Admin\Controllers\Content;
  3. use App\Admin\Exports\Content\HouseBlacklistExport;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\TalentHousePeople;
  6. use Encore\Admin\Controllers\HasResourceActions;
  7. use Encore\Admin\Grid;
  8. use Encore\Admin\Layout\Content;
  9. use Illuminate\Http\Request;
  10. class BuyHouseBlacklistController extends Controller
  11. {
  12. use HasResourceActions;
  13. private $status = ['未知', '正常', '拉黑'];
  14. /**
  15. * Index interface.
  16. *
  17. * @param Content $content
  18. * @return Content
  19. */
  20. public function index(Content $content)
  21. {
  22. return $content
  23. ->header('黑名单')
  24. ->description(' ')
  25. ->body(view('admin.content.buy_house_blacklist')->with(['grid' => $this->grid()]));
  26. }
  27. /**
  28. * Make a grid builder.
  29. *
  30. * @return Grid
  31. */
  32. protected function grid()
  33. {
  34. $grid = new Grid(new TalentHousePeople());
  35. $grid->model()->orderBy('status', 'DESC');
  36. $status_text = $this->status;
  37. $grid->id('ID');
  38. $grid->realname('姓名');
  39. $grid->mobile('联系电话');
  40. $grid->email('邮箱');
  41. $grid->id_card('证件号');
  42. $grid->end_time('拉黑截止时间');
  43. $grid->comment('备注')->style('max-width:400px');
  44. $grid->status('状态')->display(function () use ($status_text) {
  45. return $status_text[$this->status];
  46. });
  47. $grid->actions(function ($actions) {
  48. if ($actions->row['status'] == 1) {
  49. $actions->append("<a href='javascript:set_black({$actions->row['id']})' class='btn btn-danger btn-xs status'>拉黑</a>");
  50. } else {
  51. $actions->append("<a href='" . admin_base_path('content/buy_house_blacklist/status') . "?id={$actions->row['id']}&status=1' class='btn btn-primary btn-xs status'>取消拉黑</a>");
  52. }
  53. $actions->append("<a href='javascript:set_comment({$actions->row['id']})' class='btn btn-primary btn-xs comment'>修改备注</a>");
  54. });
  55. $grid->filter(function ($filter) {
  56. $filter->disableIdFilter();
  57. $filter->like('realname', '姓名');
  58. $filter->like('mobile', '手机号');
  59. $filter->like('email', '邮箱');
  60. $filter->like('id_card', '证件号');
  61. $status_option = ['全部', '正常', '拉黑'];
  62. $filter->where(function ($query) {
  63. if ($this->input > 0) {
  64. $query->where('status', '=', $this->input);
  65. }
  66. }, '状态', 'status')->radio($status_option);
  67. $filter->between('end_time', '拉黑截至时间')->datetime();
  68. });
  69. $grid->disableExport(false); //显示导出按钮
  70. $grid->exporter(new HouseBlacklistExport()); //传入自己在第1步创建的导出类
  71. return $grid;
  72. }
  73. /**
  74. * 审核
  75. */
  76. public function status(Request $request)
  77. {
  78. //接收参数
  79. $id = $request->id;
  80. $status = $request->status;
  81. $comment = $request->comment;
  82. $url = empty($request->url) ? admin_base_path('content/buy_house_blacklist') : $request->url;
  83. if (empty($id) || empty($status)) {
  84. admin_toastr('数据异常', 'error');
  85. return redirect(admin_base_path('content/buy_house_blacklist'));
  86. }
  87. //更新数据
  88. $update = ['status' => $status, 'comment' => $comment];
  89. if ($status == 2) {
  90. $end_time = $request->end_time;
  91. $update['end_time'] = $end_time;
  92. } else {
  93. $update['end_time'] = null;
  94. $update['comment'] = '';
  95. }
  96. $result = TalentHousePeople::where('id', '=', $id)
  97. ->update($update);
  98. if ($result) {
  99. admin_toastr('审核成功', 'success');
  100. } else {
  101. admin_toastr('该信息不存在或已操作', 'error');
  102. }
  103. return redirect($url);
  104. }
  105. /**
  106. * 修改备注
  107. */
  108. public function comment(Request $request)
  109. {
  110. $id = $request->id;
  111. $comment = $request->comment;
  112. $url = empty($request->url) ? admin_base_path('content/buy_house_blacklist') : $request->url;
  113. $result = TalentHousePeople::where('id', '=', $id)
  114. ->update(['comment'=>$comment]);
  115. if ($result) {
  116. admin_toastr('审核成功', 'success');
  117. } else {
  118. admin_toastr('该信息不存在或已操作', 'error');
  119. }
  120. return redirect($url);
  121. }
  122. }