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