InnerDeviceController.php 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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->get();
  24. return $this->success(['data' => $items]);
  25. }
  26. public function search(Request $request)
  27. {
  28. $items = $this->model->with('workPoint', 'spec', 'device', 'device_name');
  29. $equal_items = ['device_id', 'device_name_id', 'spec_id'];
  30. foreach ($equal_items as $item) {
  31. if($request->input($item)) {
  32. $items = $items->where($item, '=', $request->input($item));
  33. }
  34. }
  35. $like_items = ['number'];
  36. foreach ($like_items as $item) {
  37. if($request->input($item)) {
  38. $keyword = '%' . $request->input($item) . '%';
  39. $items = $items->where($item, 'like', $keyword);
  40. }
  41. }
  42. $in_items = ['project_ids', 'work_point_ids'];
  43. $key_items = ['project_id', 'work_point_id'];
  44. foreach ($in_items as $key => $item) {
  45. if($request->input($item)) {
  46. $ids = collect($request->input($item))->filter(function($id) {
  47. return $id;
  48. });
  49. if($ids->count() > 0) {
  50. $items = $items->whereIn($key_items[$key], $ids);
  51. }
  52. }
  53. }
  54. // $items = $items->orderBy('created_at');
  55. $items = $items->paginate();
  56. foreach($items as $item) {
  57. $item->status = Option::find($item->status);
  58. }
  59. return $this->success(['data' => $items->items()]);
  60. }
  61. }