Files
kulakpos_web/public/restaurant/resources/stubs/service.stub

98 lines
2.7 KiB
Plaintext
Raw Normal View History

2026-03-15 17:08:23 +07:00
<?php
namespace DummyNamespace;
use App\Interfaces\DummyModel\DummyModelInterface;
use App\Models\DummyModel;
use Illuminate\Database\Eloquent\Collection;
use Illuminate\Contracts\Pagination\LengthAwarePaginator;
final class DummyClass implements DummyModelInterface
{
public function __construct(
protected DummyModel $model
){}
/**
* Get categories by filtering args.
*/
public function get(array $args = []): \Illuminate\Database\Eloquent\Collection|\Illuminate\Database\Eloquent\Builder
{
$orderBy = empty($args['order_by']) ? 'id' : $args['order_by']; // column name
$order = empty($args['order']) ? 'asc' : $args['order']; // asc, desc
$query = DummyModel::orderBy($orderBy, $order);
if (isset($args['is_query']) && $args['is_query']) {
return $query;
}
return $query->get();
}
public function index($request, int $per_page = 50)
{
$orderColumn = request('sort_column', 'id');
$orderDirection = request('sort_direction', 'desc');
if (!in_array($orderColumn, ['id', 'name', 'created_at'])) {
$orderColumn = 'id';
}
if (!in_array($orderDirection, ['asc', 'desc'])) {
$orderDirection = 'desc';
}
return $this->model::query()
->when($request->search, function ($query) use ($request) {
$query->where('name', 'like', $request->search . '%');
})
->orderBy($orderColumn, $orderDirection)
->paginate($per_page);
}
public function getAll($request)
{
$orderColumn = request('sort_column', 'id');
$orderDirection = request('sort_direction', 'desc');
if (!in_array($orderColumn, ['id', 'name', 'created_at'])) {
$orderColumn = 'id';
}
if (!in_array($orderDirection, ['asc', 'desc'])) {
$orderDirection = 'desc';
}
return $this->model::query()
->when($request->search, function ($query) use ($request) {
$query->where('name', 'like', $request->search . '%');
})
->orderBy($orderColumn, $orderDirection)
->get();
}
public function getById(int $id)
{
$record = $this->model::find($id);
return $record ?? null;
}
public function create(array $data)
{
return $this->model::create($data);
}
public function update(int $id, array $data)
{
$model = $this->model::findOrFail($id);
$model->update($data);
return $model;
}
public function delete(int $id)
{
$model = $this->model::findOrFail($id);
return $model->delete();
}
}