InnerDeviceController.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <?php
  2. namespace App\Http\Controllers\Api\mini;
  3. use App\Models\InnerDevice;
  4. use App\Models\Option;
  5. use App\Models\WorkPoint;
  6. use Illuminate\Http\Request;
  7. class InnerDeviceController extends BaseController
  8. {
  9. protected $model;
  10. public function __construct()
  11. {
  12. $this->model = new InnerDevice();
  13. }
  14. public function get(Request $request)
  15. {
  16. if($request->input('type') == 'drop_menu') {
  17. $items = $this->model->get()->pluck('name')->unique()->map(function($item) {
  18. return collect(['text' => $item, 'value' => $item]);
  19. });
  20. $items = $items->prepend(collect(['text' => '设备名称', 'value' => '']));
  21. return $this->success(['data' => $items]);
  22. }
  23. $items = $this->model->with('device_name', 'spec', 'project');
  24. $equal_items = ['work_point_id', 'project_id'];
  25. foreach ($equal_items as $equal_item) {
  26. if($request->input($equal_item)) {
  27. $items = $items->where($equal_item, '=', $request->input($equal_item));
  28. }
  29. }
  30. $items = $items->get();
  31. return $this->success(['data' => $items]);
  32. }
  33. public function search(Request $request)
  34. {
  35. $items = $this->model->with('workPoint', 'spec', 'device', 'device_name', 'project');
  36. $equal_items = ['device_id', 'device_name_id', 'spec_id'];
  37. foreach ($equal_items as $item) {
  38. if($request->input($item)) {
  39. $items = $items->where($item, '=', $request->input($item));
  40. }
  41. }
  42. $like_items = ['number'];
  43. foreach ($like_items as $item) {
  44. if($request->input($item)) {
  45. $keyword = '%' . $request->input($item) . '%';
  46. $items = $items->where($item, 'like', $keyword);
  47. }
  48. }
  49. $in_items = ['project_ids', 'work_point_ids'];
  50. $key_items = ['project_id', 'work_point_id'];
  51. foreach ($in_items as $key => $item) {
  52. if($request->input($item)) {
  53. $ids = collect($request->input($item))->filter(function($id) {
  54. return $id;
  55. });
  56. if($ids->count() > 0) {
  57. $items = $items->whereIn($key_items[$key], $ids);
  58. }
  59. }
  60. }
  61. // $items = $items->orderBy('created_at');
  62. $stat_items = [];
  63. if($request->input('stat')) {
  64. $stat_items = $this->getStat($items);
  65. }
  66. if($request->input('free')) {
  67. $free_id = Option::get('inner_devices', 'status', 'free', 'id');
  68. $items = $items->where('status', $free_id);
  69. }
  70. $items = $items->paginate();
  71. foreach($items as $item) {
  72. $item->status = Option::find($item->status);
  73. }
  74. return $this->success(['data' => $items->items(), 'stat' => $stat_items]);
  75. }
  76. public function getStat($items)
  77. {
  78. $items = $items->get();
  79. $types = ['free', 'using', 'repair', 'scrap'];
  80. $result = [];
  81. foreach ($types as $type) {
  82. $id = Option::get('inner_devices', 'status', $type);
  83. $num = $items->where('status', $id)->count();
  84. $result[$type] = $num;
  85. }
  86. return $result;
  87. }
  88. public function detail(Request $request)
  89. {
  90. $item = $this->model->with('workPoint', 'spec', 'device', 'device_name', 'project')->find($request->input('id'));
  91. if(!$item) $this->error(['msg' => '未找到设备']);
  92. $item['status'] = Option::find($item['status']);
  93. return $this->success(['data' => $item]);
  94. }
  95. }