123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- <?php
- namespace App\Http\Controllers\Api\mini;
- use App\Models\InnerDevice;
- use App\Models\Option;
- use App\Models\WorkPoint;
- use Illuminate\Http\Request;
- class InnerDeviceController extends BaseController
- {
- protected $model;
- public function __construct()
- {
- $this->model = new InnerDevice();
- }
- public function get(Request $request)
- {
- if($request->input('type') == 'drop_menu') {
- $items = $this->model->get()->pluck('name')->unique()->map(function($item) {
- return collect(['text' => $item, 'value' => $item]);
- });
- $items = $items->prepend(collect(['text' => '设备名称', 'value' => '']));
- return $this->success(['data' => $items]);
- }
- $items = $this->model->with('device_name', 'spec', 'project');
- $equal_items = ['work_point_id', 'project_id'];
- foreach ($equal_items as $equal_item) {
- if($request->input($equal_item)) {
- $items = $items->where($equal_item, '=', $request->input($equal_item));
- }
- }
- $items = $items->get();
- return $this->success(['data' => $items]);
- }
- public function search(Request $request)
- {
- $items = $this->model->with('workPoint', 'spec', 'device', 'device_name', 'project');
- $equal_items = ['device_id', 'device_name_id', 'spec_id'];
- foreach ($equal_items as $item) {
- if($request->input($item)) {
- $items = $items->where($item, '=', $request->input($item));
- }
- }
- $like_items = ['number'];
- foreach ($like_items as $item) {
- if($request->input($item)) {
- $keyword = '%' . $request->input($item) . '%';
- $items = $items->where($item, 'like', $keyword);
- }
- }
- $in_items = ['project_ids', 'work_point_ids'];
- $key_items = ['project_id', 'work_point_id'];
- foreach ($in_items as $key => $item) {
- if($request->input($item)) {
- $ids = collect($request->input($item))->filter(function($id) {
- return $id;
- });
- if($ids->count() > 0) {
- $items = $items->whereIn($key_items[$key], $ids);
- }
- }
- }
- // $items = $items->orderBy('created_at');
- $stat_items = [];
- if($request->input('stat')) {
- $stat_items = $this->getStat($items);
- }
- if($request->input('free')) {
- $free_id = Option::get('inner_devices', 'status', 'free', 'id');
- $items = $items->where('status', $free_id);
- }
- $items = $items->paginate();
- foreach($items as $item) {
- $item->status = Option::find($item->status);
- }
- return $this->success(['data' => $items->items(), 'stat' => $stat_items]);
- }
- public function getStat($items)
- {
- $items = $items->get();
- $types = ['free', 'using', 'repair', 'scrap'];
- $result = [];
- foreach ($types as $type) {
- $id = Option::get('inner_devices', 'status', $type);
- $num = $items->where('status', $id)->count();
- $result[$type] = $num;
- }
- return $result;
- }
- public function detail(Request $request)
- {
- $item = $this->model->with('workPoint', 'spec', 'device', 'device_name', 'project')->find($request->input('id'));
- if(!$item) $this->error(['msg' => '未找到设备']);
- $item['status'] = Option::find($item['status']);
- return $this->success(['data' => $item]);
- }
- }
|