147 lines
3.8 KiB
PHP
Executable File
147 lines
3.8 KiB
PHP
Executable File
<?php
|
|
|
|
namespace Modules\Admin\app\Http\Controllers;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Traits\HasFilterRequest;
|
|
use App\Traits\HasOrderByRequest;
|
|
use App\Traits\HasSearchRequest;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Http\Response;
|
|
use Modules\Admin\app\Http\Requests\DiscountRequest;
|
|
use Modules\Admin\app\Models\Admin;
|
|
use Modules\Admin\app\Models\Discount;
|
|
use Modules\Admin\app\Models\Tracking;
|
|
|
|
class TrackingController extends Controller
|
|
{
|
|
use HasOrderByRequest;
|
|
use HasFilterRequest;
|
|
use HasSearchRequest;
|
|
|
|
public function __construct()
|
|
{
|
|
// Bỏ qua middleware 'checkApiToken' cho hàm 'myFunction'
|
|
$this->middleware('api')->except('create');
|
|
}
|
|
|
|
public function get(Request $request)
|
|
{
|
|
$tracking = new Tracking;
|
|
|
|
// Order by
|
|
$this->orderByRequest($tracking, $request);
|
|
|
|
// Filter
|
|
$this->filterRequest(
|
|
builder: $tracking,
|
|
request: $request,
|
|
filterKeys: [
|
|
'created_at' => self::F_IN_DATETIME,
|
|
'time_string' => self::F_TEXT,
|
|
'name' => self::F_TEXT,
|
|
'status' => self::F_TEXT
|
|
]
|
|
);
|
|
|
|
$this->searchRequest(
|
|
builder: $tracking,
|
|
value: $request->get('search'),
|
|
fields: [
|
|
'name',
|
|
'time_string',
|
|
'status'
|
|
]
|
|
);
|
|
|
|
$responseData = array_merge(
|
|
$tracking->paginate($request->get('per_page'))->toArray(),
|
|
['status' => true]
|
|
);
|
|
|
|
return response()->json($responseData);
|
|
}
|
|
|
|
public function create(Request $request)
|
|
{
|
|
$payload = $request->only(['name', 'time_string', 'status']);
|
|
$user = Admin::where('name', $payload['name'])->first();
|
|
if($user){
|
|
$payload['user_id'] = $user->id;
|
|
$tracking = Tracking::create($payload);
|
|
return response()->json([
|
|
'data' => $tracking,
|
|
'status' => true
|
|
]);
|
|
}
|
|
|
|
return response()->json([
|
|
'data' => "USER NOT EXIST",
|
|
'status' => false
|
|
]);
|
|
|
|
}
|
|
|
|
public function update(DiscountRequest $request)
|
|
{
|
|
$id = $request->get('id');
|
|
|
|
$discount = Discount::find($id);
|
|
$payload = $request->all();
|
|
|
|
if ($discount) {
|
|
$discount->update($payload);
|
|
}
|
|
return response()->json([
|
|
'data' => $discount,
|
|
'status' => true
|
|
]);
|
|
}
|
|
|
|
public function delete(DiscountRequest $request)
|
|
{
|
|
$id = $request->get('id');
|
|
|
|
Discount::destroy($id);
|
|
return response()->json([
|
|
'status' => true
|
|
]);
|
|
}
|
|
|
|
// Delete multiple discounts
|
|
public function deletes(DiscountRequest $request)
|
|
{
|
|
$discounts = $request->get('discounts');
|
|
$ids = collect($discounts)->pluck('id');
|
|
Discount::whereIn('id', $ids)->delete();
|
|
return response()->json([
|
|
'data' => $ids,
|
|
'status' => true
|
|
]);
|
|
}
|
|
|
|
// Update multiple discounts
|
|
public function updates(DiscountRequest $request)
|
|
{
|
|
$discounts = $request->get('discounts');
|
|
$ids = collect($discounts)->pluck('id');
|
|
|
|
foreach ($discounts as $discountRequest) {
|
|
// convert to object|array to array
|
|
$discountRequest = collect($discountRequest)->toArray();
|
|
// handle array
|
|
$discount = Discount::find($discountRequest['id']);
|
|
if ($discount) {
|
|
// exclude id field
|
|
unset($discount['id']);
|
|
|
|
$discount->update($discountRequest);
|
|
}
|
|
}
|
|
return response()->json([
|
|
'data' => Discount::whereIn('id', $ids)->get(),
|
|
'status' => true
|
|
]);
|
|
}
|
|
}
|