Offtaker
This commit is contained in:
parent
ab4da668bd
commit
6568eb8f1e
123
app/Http/Controllers/Api/OfftakerController.php
Normal file
123
app/Http/Controllers/Api/OfftakerController.php
Normal file
@ -0,0 +1,123 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Api;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Support\Facades\Gate;
|
||||
use App\Models\Offtaker;
|
||||
|
||||
class OfftakerController extends Controller
|
||||
{
|
||||
public function index(): JsonResponse
|
||||
{
|
||||
Gate::authorize('super_admin');
|
||||
|
||||
$listOfftaker = Offtaker::all();
|
||||
|
||||
return response()->json($listOfftaker);
|
||||
}
|
||||
|
||||
public function store(Request $request): JsonResponse
|
||||
{
|
||||
Gate::authorize('super_admin');
|
||||
|
||||
$validated = $request->validate([
|
||||
'user_email' => ['required', 'email', 'max:255'],
|
||||
'company_name' => ['required', 'string', 'max:255'],
|
||||
'contact_name' => ['nullable', 'string', 'max:255'],
|
||||
'phone' => ['nullable', 'string', 'max:20'],
|
||||
'address' => ['nullable', 'string'],
|
||||
'is_active' => ['nullable', 'boolean'],
|
||||
]);
|
||||
|
||||
$offtaker = Offtaker::create([
|
||||
'user_email' => $validated['user_email'],
|
||||
'company_name' => $validated['company_name'],
|
||||
'contact_name' => $validated['contact_name'] ?? null,
|
||||
'phone' => $validated['phone'] ?? null,
|
||||
'address' => $validated['address'] ?? null,
|
||||
'is_active' => $validated['is_active'] ?? true,
|
||||
'sync_status' => 'synced',
|
||||
'created_date' => now(),
|
||||
]);
|
||||
|
||||
return response()->json($offtaker, 201);
|
||||
}
|
||||
|
||||
public function show(string $id): JsonResponse
|
||||
{
|
||||
Gate::authorize('super_admin');
|
||||
$offtaker = Offtaker::findOrFail($id);
|
||||
return response()->json($offtaker);
|
||||
}
|
||||
|
||||
public function update(Request $request, string $id): JsonResponse
|
||||
{
|
||||
Gate::authorize('super_admin');
|
||||
$offtaker = Offtaker::findOrFail($id);
|
||||
|
||||
$validated = $request->validate([
|
||||
'user_email' => ['email', 'max:255'],
|
||||
'company_name' => ['string', 'max:255'],
|
||||
'contact_name' => ['nullable', 'string'],
|
||||
'phone' => ['nullable', 'string'],
|
||||
'address' => ['nullable', 'string'],
|
||||
'is_active' => ['boolean'],
|
||||
]);
|
||||
|
||||
$offtaker->update($validated);
|
||||
return response()->json($offtaker);
|
||||
}
|
||||
|
||||
public function destroy(string $id): JsonResponse
|
||||
{
|
||||
Gate::authorize('super_admin');
|
||||
// Menggunakan Soft Delete (Eloquent otomatis handle karena ada trait SoftDeletes di model)
|
||||
Offtaker::findOrFail($id)->delete();
|
||||
|
||||
return response()->json(null, 204);
|
||||
}
|
||||
|
||||
/**
|
||||
* Digunakan untuk sinkronisasi massal dari data lokal (offline)
|
||||
*/
|
||||
public function batchUpsert(Request $request): JsonResponse
|
||||
{
|
||||
Gate::authorize('super_admin');
|
||||
|
||||
$validated = $request->validate([
|
||||
'offtakers' => ['required', 'array'],
|
||||
'offtakers.*.id' => ['nullable', 'integer'],
|
||||
'offtakers.*.user_email' => ['required', 'email'],
|
||||
'offtakers.*.company_name' => ['required', 'string'],
|
||||
'offtakers.*.contact_name' => ['nullable', 'string'],
|
||||
'offtakers.*.phone' => ['nullable', 'string'],
|
||||
'offtakers.*.address' => ['nullable', 'string'],
|
||||
]);
|
||||
|
||||
$dataUpsert = [];
|
||||
foreach ($validated['offtakers'] as $item) {
|
||||
$dataUpsert[] = [
|
||||
'id' => $item['id'] ?? null,
|
||||
'user_email' => $item['user_email'],
|
||||
'company_name' => $item['company_name'],
|
||||
'contact_name' => $item['contact_name'] ?? null,
|
||||
'phone' => $item['phone'] ?? null,
|
||||
'address' => $item['address'] ?? null,
|
||||
'sync_status' => 'synced',
|
||||
'is_active' => true,
|
||||
'created_at' => now(),
|
||||
'updated_at' => now(),
|
||||
];
|
||||
}
|
||||
|
||||
// Melakukan upsert berdasarkan ID
|
||||
Offtaker::upsert($dataUpsert, ['id'], [
|
||||
'user_email', 'company_name', 'contact_name', 'phone', 'address', 'sync_status', 'updated_at'
|
||||
]);
|
||||
|
||||
return response()->json(['status' => 'success'], 200);
|
||||
}
|
||||
}
|
||||
@ -17,9 +17,8 @@ public function index(): JsonResponse
|
||||
Gate::authorize('petani');
|
||||
|
||||
$user = Auth::user();
|
||||
// Mengasumsikan farmer_id di data panen merujuk pada profile->id atau user_id
|
||||
$listPanen = Panen::where('farmer_id', $user->profile->id)->get();
|
||||
|
||||
|
||||
return response()->json($listPanen);
|
||||
}
|
||||
|
||||
|
||||
25
app/Models/Map/Offtaker.php
Normal file
25
app/Models/Map/Offtaker.php
Normal file
@ -0,0 +1,25 @@
|
||||
<?php
|
||||
namespace App\Models;
|
||||
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
use Illuminate\Database\Eloquent\SoftDeletes; // Wajib diimport
|
||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||
|
||||
class Offtaker extends Model
|
||||
{
|
||||
use HasFactory, SoftDeletes;
|
||||
|
||||
protected $table = 'offtakers';
|
||||
|
||||
protected $fillable = [
|
||||
'user_email',
|
||||
'company_name',
|
||||
'contact_name',
|
||||
'phone',
|
||||
'address',
|
||||
'is_active',
|
||||
'sync_status',
|
||||
'created_date'
|
||||
];
|
||||
protected $dates = ['deleted_at', 'created_date'];
|
||||
}
|
||||
@ -31,6 +31,7 @@
|
||||
Route::apiResource('/tanaman', \App\Http\Controllers\Api\TanamanController::class)->except(['create', 'edit']);
|
||||
Route::apiResource('/inspeksi', \App\Http\Controllers\Api\InspeksiController::class)->except(['create', 'edit']);
|
||||
Route::apiResource('/panen', \App\Http\Controllers\Api\PanenController::class)->except(['create', 'edit']);
|
||||
Route::apiResource('/offtaker', \App\Http\Controllers\Api\OfftakerController::class)->except(['create', 'edit']);
|
||||
});
|
||||
|
||||
Route::middleware('auth:sanctum')
|
||||
|
||||
Loading…
Reference in New Issue
Block a user