| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 | <?phpnamespace 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]);    }}
 |