VaccinesController.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  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->equal('organizationvaccines.org_id','机构')->select(Organization::pluck('name','id'));
  71. });
  72. });
  73. //按关键字查询
  74. $grid->quickSearch(function ($model, $query) {
  75. //$model->whereHas('Vaccines',function ($model) use ($query) {
  76. $model->where('type', 'like', "%{$query}%")
  77. ->orWhere('name', 'like', "%{$query}%")
  78. ->orWhere('id',$query)
  79. ->orwhere('supplier','like',"%{$query}%")
  80. ->orwhere('remark','like',"{$query}");
  81. //});
  82. })->placeholder('请输入疫苗id/名称/厂家/备注');
  83. $grid->export(function ($export) {
  84. //文件名
  85. $export->filename('测试');
  86. //排除字段不用导出
  87. $export->except(['created_at', 'updated_at']);
  88. $export->originalValue(['states']);
  89. });
  90. $grid->tools(function (Grid\Tools $tools) {
  91. $tools->append(new ImportAction());
  92. });
  93. return $grid;
  94. }
  95. /**
  96. * Make a show builder.
  97. *
  98. * @param mixed $id
  99. * @return Show
  100. */
  101. protected function detail($id)
  102. {
  103. $show = new Show(Vaccines::findOrFail($id));
  104. $show->field('id', __('Id'));
  105. $show->field('type', __('分类'))->using([1=>'Ⅰ类疫苗',2=>'Ⅱ类疫苗']);
  106. $show->field('introduction','简介');
  107. $show->field('price', __('价钱'));
  108. $show->field('name', __('名称'));
  109. $show->field('remark', __('备注'));
  110. $show->field('supplier', __('厂家'));
  111. $show->field('created_at', __('创建时间'));
  112. $show->field('updated_at', __('更新时间'));
  113. return $show;
  114. }
  115. /**
  116. * Make a form builder.
  117. *
  118. * @return Form
  119. */
  120. protected function form()
  121. {
  122. $form = new Form(new Vaccines());
  123. $form->select('type', __('分类'))->options(Vaccines::$_post_type)->default('1');
  124. $form->text('name', __('名称'))->rules('required|min:3|max:255',['required'=>'请填写名称','min'=>'名称不能少于3个字符!','max'=>'名称长度过长!']);
  125. // $form->text('introduction','简介')->rules('required',['require'=>'请填写疫苗简介!' ]);
  126. $form->currency('price', __('价格'))->symbol('分');
  127. $form->text('remark', __('备注'))->rules('required',['required'=>'请填写备注!']);;
  128. $form->text('supplier', __('厂家'))->rules('required',['required'=>'请填写厂家!']);
  129. $form->number('stock','库存');
  130. $states = [
  131. 'off' => ['value' => 0, 'text' => '禁用', 'color' => 'danger'],
  132. 'on' => ['value' => 1, 'text' => '启用', 'color' => 'success'],
  133. ];
  134. $form->switch('states','状态')->states($states);
  135. return $form;
  136. }
  137. }