VaccinesController.php 5.4 KB

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