VaccinesController.php 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. <?php
  2. namespace App\Admin\Controllers\VaccinesManagement;
  3. use App\Models\Organization;
  4. use App\Models\Vaccines;
  5. use App\Admin\Actions\Vaccines\ImportAction;
  6. use Encore\Admin\Controllers\AdminController;
  7. use Encore\Admin\Form;
  8. use Encore\Admin\Grid;
  9. use Encore\Admin\Show;
  10. use Encore\Admin\Widgets\Table;
  11. class VaccinesController extends AdminController
  12. {
  13. /**
  14. * Title for current resource.
  15. *
  16. * @var string
  17. */
  18. protected $title = '疫苗管理';
  19. /**
  20. * Make a grid builder.
  21. *
  22. * @return Grid
  23. */
  24. protected function grid()
  25. {
  26. $grid = new Grid(new Vaccines());
  27. $grid->model()->orderBy('id','desc');
  28. $grid->column('id', __('Id'));
  29. $grid->column('type', '类型')->using([1=>'Ⅰ类疫苗',2=>'Ⅱ类疫苗']);
  30. $grid->column('name', __('名称'));
  31. // $grid->column('introduction','简介');
  32. $grid->column('price', __('价钱'));
  33. $grid->column('remark', __('备注'));
  34. $grid->column('supplier', __('厂家'));
  35. $states = [
  36. 'on' => ['value' => 1, 'text' => '启用', 'color' => 'success'],
  37. 'off' => ['value' => 0, 'text' => '禁用', 'color' => 'danger'],
  38. ];
  39. $grid->column('organizations', '机构')->display(function (){
  40. return '点击查看';
  41. })->modal('机构库存', function ($model) {
  42. $org = $model->organizationvaccines()->get()->map(function ($comment) {
  43. return $comment->only(['org_id', 'stock']);
  44. });
  45. $org = $org->toArray();
  46. for($i=0;$i<count($org);$i++)
  47. {
  48. $id = $org[$i]['org_id'];
  49. $org[$i]['org_name'] = Organization::where('id',$id)->value('name');
  50. }
  51. return new Table(['ID', '库存' ,'机构名称'], $org);
  52. });
  53. $grid->column('stock','库存');
  54. $grid->column('states','状态')->switch($states);
  55. $grid->column('created_at', __('创建时间'));
  56. $grid->column('updated_at', __('更新时间'));
  57. $grid->filter(function($filter){
  58. /*
  59. 搜索:按关键字、ID搜索
  60. 筛选:类别筛选
  61. 导入、导出
  62. */
  63. // 在这里添加字段过滤器
  64. $filter->column(1/2, function ($filter) {
  65. $filter->equal('type', '类型')->select(Vaccines::$_post_type);
  66. $filter->equal('supplier','厂家');
  67. });
  68. $filter->column(1/2, function ($filter) {
  69. $filter->equal('name','疫苗名称');
  70. // $filter->in('organizations','机构名称')->select(Organization::all()->pluck('name','id'));
  71. $filter->where(function ($query) {
  72. $query->join('organization_vaccines', 'organization_vaccines.vaccine_id', '=', 'vaccines.id')
  73. ->where('organization_vaccines.org_id',$this->input);
  74. },'机构名称')->select(Organization::all()->pluck('name','id'));
  75. // $filter->where(function ($model){
  76. // $model->whereHas('organizationvaccines',function ($model) {
  77. // $model->join('vaccines', 'organization_vaccines.vaccine_id', '=', 'vaccines.id')
  78. // ->where('vaccines.id',$this->input)
  79. // ->get();
  80. // });
  81. //
  82. // },'机构名称1')->select(Organization::all()->pluck('name','id'));
  83. });
  84. });
  85. //按关键字查询
  86. $grid->quickSearch(function ($model, $query) {
  87. //$model->whereHas('Vaccines',function ($model) use ($query) {
  88. $model->where('type', 'like', "%{$query}%")
  89. ->orWhere('name', 'like', "%{$query}%")
  90. ->orWhere('id',$query)
  91. ->orwhere('supplier','like',"%{$query}%")
  92. ->orwhere('remark','like',"{$query}");
  93. //});
  94. })->placeholder('请输入疫苗id/名称/厂家/备注');
  95. $grid->export(function ($export) {
  96. //文件名
  97. $export->filename('测试');
  98. //排除字段不用导出
  99. $export->except(['created_at', 'updated_at']);
  100. $export->originalValue(['states']);
  101. });
  102. $grid->tools(function (Grid\Tools $tools) {
  103. $tools->append(new ImportAction());
  104. });
  105. return $grid;
  106. }
  107. /**
  108. * Make a show builder.
  109. *
  110. * @param mixed $id
  111. * @return Show
  112. */
  113. protected function detail($id)
  114. {
  115. $show = new Show(Vaccines::findOrFail($id));
  116. $show->field('id', __('Id'));
  117. $show->field('type', __('分类'))->using([1=>'Ⅰ类疫苗',2=>'Ⅱ类疫苗']);
  118. $show->field('introduction','简介');
  119. $show->field('price', __('价钱'));
  120. $show->field('name', __('名称'));
  121. $show->field('remark', __('备注'));
  122. $show->field('supplier', __('厂家'));
  123. $show->field('created_at', __('创建时间'));
  124. $show->field('updated_at', __('更新时间'));
  125. return $show;
  126. }
  127. /**
  128. * Make a form builder.
  129. *
  130. * @return Form
  131. */
  132. protected function form()
  133. {
  134. $form = new Form(new Vaccines());
  135. $form->select('type', __('分类'))->options(Vaccines::$_post_type)->default('1');
  136. $form->text('name', __('名称'))->rules('required|min:3|max:255',['required'=>'请填写名称','min'=>'名称不能少于3个字符!','max'=>'名称长度过长!']);
  137. // $form->text('introduction','简介')->rules('required',['require'=>'请填写疫苗简介!' ]);
  138. $form->currency('price', __('价格'))->symbol('分');
  139. $form->text('remark', __('备注'))->rules('required',['required'=>'请填写备注!']);;
  140. $form->text('supplier', __('厂家'))->rules('required',['required'=>'请填写厂家!']);
  141. $form->number('stock','库存');
  142. $states = [
  143. 'off' => ['value' => 0, 'text' => '禁用', 'color' => 'danger'],
  144. 'on' => ['value' => 1, 'text' => '启用', 'color' => 'success'],
  145. ];
  146. $form->switch('states','状态')->states($states);
  147. return $form;
  148. }
  149. }