InnerDeviceController.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. <?php
  2. namespace App\Http\Controllers\Api\mini;
  3. use App\Models\InnerDevice;
  4. use App\Models\InnerDeviceNamesModel;
  5. use App\Models\Option;
  6. use App\Models\Order;
  7. use App\Models\OrderDevice;
  8. use App\Models\WorkPoint;
  9. use Illuminate\Http\Request;
  10. class InnerDeviceController extends BaseController
  11. {
  12. protected $model;
  13. public function __construct()
  14. {
  15. $this->model = new InnerDevice();
  16. }
  17. public function get(Request $request)
  18. {
  19. if($request->input('type') == 'drop_menu') {
  20. $items = $this->model->get()->pluck('name')->unique()->map(function($item) {
  21. return collect(['text' => $item, 'value' => $item]);
  22. });
  23. $items = $items->prepend(collect(['text' => '设备名称', 'value' => '']));
  24. return $this->success(['data' => $items]);
  25. }
  26. $items = $this->model->with('device_name', 'spec', 'project');
  27. $equal_items = ['work_point_id', 'project_id'];
  28. $project_id = $request->input('project_id');
  29. if(!empty($project_id)){
  30. $device_ids = OrderDevice::where('project_id',$project_id)->whereHas('order',function ($query){
  31. $query->where('status','=',2)->where('level','=',2)->whereIn('last_project_role_id',[5,7]);
  32. })->pluck('inner_device_id')->toArray();
  33. $items = $items->whereIn('id',$device_ids);
  34. }
  35. foreach ($equal_items as $equal_item) {
  36. if($request->input($equal_item)) {
  37. $items = $items->where($equal_item, '=', $request->input($equal_item));
  38. }
  39. }
  40. if($request->input('status') == 'using') {
  41. $using_id = Option::get('inner_devices', 'status', 'using');
  42. $items = $items->where(['status'=>$using_id]);
  43. }
  44. $items = $items->get();
  45. return $this->success(['data' => $items]);
  46. }
  47. public function search(Request $request)
  48. {
  49. $items = $this->model->with('workPoint', 'spec', 'device', 'project');
  50. $equal_items = [ 'device_name_id', 'spec_name'];
  51. foreach ($equal_items as $item) {
  52. if($request->input($item)) {
  53. $items = $items->where($item, '=', $request->input($item));
  54. }
  55. }
  56. $like_items = ['number'];
  57. foreach ($like_items as $item) {
  58. if($request->input($item)) {
  59. $keyword = '%' . $request->input($item) . '%';
  60. // $items = $items->where($item, 'like', $keyword);
  61. $items->where(function ($query) use ($keyword) {
  62. $query->where('number', 'like', $keyword)
  63. ->orWhere('spec_name', 'like', $keyword);
  64. });
  65. }
  66. }
  67. $in_items = ['project_ids', 'work_point_ids'];
  68. $key_items = ['project_id', 'work_point_id'];
  69. foreach ($in_items as $key => $item) {
  70. if($request->input($item)) {
  71. $ids = collect($request->input($item))->filter(function($id) {
  72. return $id;
  73. });
  74. if($ids->count() > 0) {
  75. $items = $items->whereIn($key_items[$key], $ids);
  76. }
  77. }
  78. }
  79. // $items = $items->orderBy('created_at');
  80. $stat_items = [];
  81. if($request->input('stat')) {
  82. $stat_items = $this->getStat($items);
  83. }
  84. $status_field = $request->input('status');
  85. if($status_field) {
  86. $free_id = Option::get('inner_devices', 'status', $status_field, 'id');
  87. $items = $items->where('status', $free_id);
  88. }
  89. $items = $items->paginate();
  90. foreach($items as $item) {
  91. $item->status = Option::find($item->status);
  92. }
  93. return $this->success(['data' => $items->items(), 'stat' => $stat_items]);
  94. }
  95. public function getStat($items)
  96. {
  97. $items = $items->get();
  98. $types = ['free', 'using', 'repair', 'scrap'];
  99. $result = [];
  100. foreach ($types as $type) {
  101. $id = Option::get('inner_devices', 'status', $type);
  102. $num = $items->where('status', $id)->count();
  103. $result[$type] = $num;
  104. }
  105. return $result;
  106. }
  107. public function detail(Request $request)
  108. {
  109. $item = $this->model->with('workPoint', 'spec', 'device', 'device_name', 'project')->find($request->input('id'));
  110. if(!$item) $this->error(['msg' => '未找到设备']);
  111. $item['status'] = Option::find($item['status']);
  112. return $this->success(['data' => $item]);
  113. }
  114. //设备三级联动
  115. public function getDeviceName(Request $request)
  116. {
  117. $items = InnerDeviceNamesModel::select( 'name as text','id as value')->get();
  118. $items = $items->prepend($this->transObject(['text' => '设备名称', 'value' => '']));
  119. return $this->success(['data' => $items]);
  120. }
  121. public function transObject($items)
  122. {
  123. return json_decode(json_encode($items));
  124. }
  125. }