InsuranceListController.php 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. <?php
  2. namespace App\Admin\Controllers\OrdersManagement;
  3. use App\Models\Order;
  4. use App\Models\OrderPack;
  5. use Encore\Admin\Controllers\AdminController;
  6. use Encore\Admin\Form;
  7. use Encore\Admin\Grid;
  8. use Encore\Admin\Show;
  9. class InsuranceListController extends AdminController
  10. {
  11. /**
  12. * Title for current resource.
  13. *
  14. * @var string
  15. */
  16. protected $title = '保险信息列表';
  17. /**
  18. * Make a grid builder.
  19. *
  20. * @return Grid
  21. */
  22. protected function grid()
  23. {
  24. $grid = new Grid(new OrderPack());
  25. $grid->model()->where(function ($query){
  26. $query->whereHas('servicepacks',function ($query){
  27. $query->where('is_need_insure','=',1);
  28. });
  29. });
  30. $grid->actions(function ($actions){
  31. $actions->disableView();
  32. $actions->disableDelete();
  33. });
  34. $grid->filter(function ($filter){
  35. $filter->disableIdFilter();
  36. $filter->like('pack_name','服务包名称');
  37. $filter->like('orderpatients.name','患者姓名');
  38. $filter->equal('users.phone','用户电话');
  39. $filter->equal('is_need_insurance','是否包含保单')->select([0=>'否',1=>'是']);
  40. });
  41. $grid->disableCreateButton();
  42. //实现只有服务包中包含保单的才显示进来
  43. $grid->model()->orderBy('id','desc');
  44. $grid->column('order_id', __('订单id'))->sortable();
  45. $grid->column('pack_name', __('服务包名称'));
  46. $grid->column('orderpatients.name', __('患者姓名'));
  47. $grid->column('orderpatients.guardian_name', __('监护人姓名'));
  48. $grid->column('orderpatients.sex', __('性别'))->using([0=>'未知',1=>'男',2=>'女']);
  49. $grid->column('orderpatients.relationship_type', __('与投保人的关系'))
  50. ->using([1=>'父亲',2=>'母亲',3=>'祖父',4=>'祖母',5=>'外祖父',6=>'外祖母',7=>'叔侄',8=>'其他']);
  51. $grid->column('orderpatients.id', __('患者id'))->hide();
  52. $grid->column('users.phone', __('用户电话'));
  53. // //保单信息
  54. $grid->column('orderpatients.birthday', __('出生日期'));
  55. $grid->column('orderpatients.card_type', __('证件类型'))->using([1=>'身份证',2=>'护照']);
  56. $grid->column('orderpatients.card_number', __('证件号码'));
  57. $grid->column('is_need_insurance', __('是否需要保单'))->using([0=>'否',1=>'是']);
  58. $grid->column('insurance_img_url', __('保单'))->link()->display(function (){
  59. // dd($url);
  60. $img = OrderPack::where('order_id',$this->order_id)->value('insurance_img_url');
  61. // dd($img);
  62. if (empty($img))
  63. {
  64. return '';
  65. }
  66. else
  67. {
  68. $herf = '../upload/'.$img;
  69. $url = "<a href=$herf target='_blank'>保单查看</a>";
  70. return $url;
  71. }
  72. });
  73. $grid->column('order.order_status', __('订单状态'))->using([1=>'未支付',2=>'待接单',3=>'进行中',4=>'已完成',5=>'已取消']);
  74. return $grid;
  75. }
  76. protected function form()
  77. {
  78. $form = new Form(new OrderPack());
  79. $form->file('insurance_img_url','保单文件')->help('请上传pdf文件')->rules('required|mimes:pdf');
  80. return $form;
  81. }
  82. }