- 회사명: 생성 시 테넌트 company_name 자동입력 - 분류: select 변경 (수입검사/중간검사/품질검사 + 커스텀) - 수입검사 → 품목 다중선택 (RM, SM 필터) - 품질검사 → 공정 선택 - 결재라인 단계명: text → select (작성/검토/승인/참조) - 작성 단계: (작성자) 표시, user_id=null - 검토/승인/참조: 테넌트 사용자 검색/선택, user_id 저장 - 공정 검색 API, 테넌트 사용자 검색 API 신규 추가 - ItemApiController에 item_type, ids 파라미터 지원 추가 Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
45 lines
1.3 KiB
PHP
45 lines
1.3 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api\Admin;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Models\Items\Item;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\Request;
|
|
|
|
class ItemApiController extends Controller
|
|
{
|
|
/**
|
|
* 품목 검색 (datalist 자동완성용)
|
|
*/
|
|
public function search(Request $request): JsonResponse
|
|
{
|
|
$tenantId = session('selected_tenant_id');
|
|
$query = $request->input('q', '');
|
|
|
|
$items = Item::query()
|
|
->where('tenant_id', $tenantId)
|
|
->where('is_active', true)
|
|
->when($query, function ($q) use ($query) {
|
|
$q->where(function ($sub) use ($query) {
|
|
$sub->where('name', 'like', "%{$query}%")
|
|
->orWhere('code', 'like', "%{$query}%");
|
|
});
|
|
})
|
|
->when($request->input('item_type'), function ($q, $types) {
|
|
$q->whereIn('item_type', explode(',', $types));
|
|
})
|
|
->when($request->input('ids'), function ($q, $ids) {
|
|
$q->whereIn('id', explode(',', $ids));
|
|
})
|
|
->orderBy('name')
|
|
->limit(30)
|
|
->get(['id', 'code', 'name', 'item_type', 'unit']);
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'data' => $items,
|
|
]);
|
|
}
|
|
}
|