fix resources hospital

This commit is contained in:
Muhammad Fajar
2022-11-03 15:52:51 +07:00
parent 5f8515feac
commit 6a57b8179a
6 changed files with 62 additions and 75 deletions

View File

@@ -45,10 +45,10 @@ class DashboardController extends Controller
->active()
->hospital()
->when($request->lat && $request->lng, function ($query) use ($request) {
$query->selectRaw("organizations.id, organizations.name, addresses.text AS address, cities.name AS city_name, 6371 * acos (cos ( radians($request->lat) ) * cos( radians( addresses.lat ) ) * cos( radians( addresses.lng ) - radians($request->lng) ) + sin ( radians($request->lat) ) * sin( radians( addresses.lat ) )) as distance");
$query->selectRaw("organizations.*, addresses.text AS address, addresses.lat, addresses.lng, cities.name AS city_name, 6371 * acos (cos ( radians($request->lat) ) * cos( radians( addresses.lat ) ) * cos( radians( addresses.lng ) - radians($request->lng) ) + sin ( radians($request->lat) ) * sin( radians( addresses.lat ) )) as distance");
$query->orderBy('distance', 'ASC');
}, function ($query) {
$query->select(['organizations.id', 'organizations.name', 'addresses.text AS address', 'cities.name AS city_name']);
$query->select(['organizations.*', 'addresses.text AS address', 'addresses.lat', 'addresses.lng', 'cities.name AS city_name']);
$query->orderBy('organizations.name', 'asc');
})
->limit($limit)

View File

@@ -4,6 +4,7 @@ namespace Modules\Linksehat\Http\Controllers\Api;
use App\Helpers\Helper;
use App\Models\Organization;
use App\Models\Speciality;
use Illuminate\Contracts\Support\Renderable;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Http\Request;
@@ -100,23 +101,41 @@ class HospitalController extends Controller
public function show(Request $request, $id)
{
$queryHospitals = Organization::query()
->with(['practitionerRoles' => function ($query) {
$query->select(['organization_id', 'speciality_id'])
->whereNot('speciality_id')
->groupBy(['speciality_id'])
->orderBy('speciality_id');
}])
->when($request->lat && $request->lng, function (Builder $query) use ($request) {
$query->selectRaw("organizations*, addresses.text AS address, cities.name AS city_name, 6371 * acos (cos ( radians($request->lat) ) * cos( radians( addresses.lat ) ) * cos( radians( addresses.lng ) - radians($request->lng) ) + sin ( radians($request->lat) ) * sin( radians( addresses.lat ) )) as distance");
$query->orderBy('distance', 'ASC');
}, function ($query) {
$query->select(['organizations.*', 'addresses.text AS address', 'cities.name AS city_name']);
$query->orderBy('organizations.name', 'asc');
$query->getQuery()
->selectRaw("organizations.*, addresses.text AS address, addresses.lat, addresses.lng, cities.name AS city_name, 6371 * acos (cos ( radians($request->lat) ) * cos( radians( addresses.lat ) ) * cos( radians( addresses.lng ) - radians($request->lng) ) + sin ( radians($request->lat) ) * sin( radians( addresses.lat ) )) as distance")
->orderBy('distance', 'ASC');
}, function (Builder $query) {
$query->getQuery()
->select(['organizations.*', 'addresses.text AS address', 'addresses.lat', 'addresses.lng', 'cities.name AS city_name'])
->groupBy(['organizations.id'])
->orderBy('organizations.name');
})
->leftJoin('addresses', function ($q) {
$q->on('organizations.main_address_id', '=', 'addresses.id');
$q->where('addresses.addressable_type', '=', Organization::class);
->leftJoin('addresses', function ($query) {
$query->on('organizations.main_address_id', '=', 'addresses.id');
})
->leftJoin('cities', function ($query) {
$query->on('addresses.city_id', '=', 'cities.id');
});
$queryHospitals = $queryHospitals->orderBy('organizations.name', 'asc')->findOrFail($id);
})
->where('organizations.id', $id)
->where('addresses.addressable_type', '=', Organization::class)
->findOrFail($id);
return Helper::responseJson(new HospitalResource($queryHospitals));
foreach ($queryHospitals->practitionerRoles as $practitionerRole) {
$specialitiesId[] = $practitionerRole->speciality_id;
}
$queryHospitals['specialities'] = Speciality::query()
->whereIn('id', $specialitiesId)
->get();
return Helper::responseJson(['hospitals' => new HospitalResource($queryHospitals)]);
}
/**

View File

@@ -2,8 +2,8 @@
namespace Modules\Linksehat\Transformers\Hospital;
use App\Models\PractitionerRole;
use Illuminate\Http\Resources\Json\JsonResource;
use Modules\Linksehat\Transformers\Speciality\SpecialityForHospitalDetailResource;
class HospitalResource extends JsonResource
{
@@ -15,20 +15,6 @@ class HospitalResource extends JsonResource
*/
public function toArray($request)
{
$querySpecialitys = PractitionerRole::query()
->with(['speciality'])
->where('organization_id', $this->id)
->whereNotNull('speciality_id')
->orderBy('speciality_id')
->groupBy('speciality_id')
->get(['speciality_id']);
foreach ($querySpecialitys as $indexSpeciality => $speciality) {
$specialitys[$indexSpeciality]['id'] = $speciality->speciality->id;
$specialitys[$indexSpeciality]['name'] = $speciality->speciality->name;
$specialitys[$indexSpeciality]['avatar'] = asset('images/default-specialisasi-image.png');
}
return [
'id' => $this->id,
'name' => $this->name,
@@ -45,7 +31,10 @@ class HospitalResource extends JsonResource
'photos' => [
'title' => $this->name,
'photo_url' => url('images/default-hospital-image.png'),
]
],
$this->mergeWhen($this->specialities, [
'specialities' => SpecialityForHospitalDetailResource::collection($this->specialities)
])
];
}
}

View File

@@ -1,45 +0,0 @@
<?php
namespace Modules\Linksehat\Transformers\Hospital;
use App\Models\PractitionerRole;
use Illuminate\Http\Resources\Json\JsonResource;
use Str;
class HospitalResourceDetail extends JsonResource
{
/**
* Transform the resource into an array.
*
* @param \Illuminate\Http\Request
* @return array
*/
public function toArray($request)
{
$querySpecialitys = PractitionerRole::query()
->with(['speciality'])
->where('organization_id', $this->id)
->whereNotNull('speciality_id')
->orderBy('speciality_id')
->groupBy('speciality_id')
->get(['speciality_id']);
foreach ($querySpecialitys as $indexSpeciality => $speciality) {
$specialitys[$indexSpeciality]['id'] = $speciality->speciality->id;
$specialitys[$indexSpeciality]['name'] = $speciality->speciality->name;
$specialitys[$indexSpeciality]['avatar'] = asset('images/default-specialisasi-image.png');
}
return [
'id' => $this->id,
'name' => $this->name,
'address' => $address ?? null,
'distance' => $this->distance ? ($this->distance < 1 ? round($this->distance * 1000, 2) . " m" : round($this->distance, 2) . " km") : null,
'photos' => [
'title' => Str::slug($this->name),
'url' => asset('images/default-hospital-image.png'),
],
'specialitys' => $specialitys
];
}
}

View File

@@ -0,0 +1,24 @@
<?php
namespace Modules\Linksehat\Transformers\Speciality;
use App\Helpers\Helper;
use Illuminate\Http\Resources\Json\JsonResource;
class SpecialityForHospitalDetailResource extends JsonResource
{
/**
* Transform the resource into an array.
*
* @param \Illuminate\Http\Request
* @return array
*/
public function toArray($request)
{
return [
'id' => $this->id,
'name' => 'Spesialis ' . $this->name,
'avatar' => url('images/default-hospital-image.png'),
];
}
}

View File

@@ -36,7 +36,7 @@ class SpecialityResource extends JsonResource
'specialis' => 'Spesialis ' . (isset($this->speciality->name) ? $this->speciality->name : $this->speciality_name),
'experience' => rand(5, 12),
'rating' => rand(20, 100),
'price' => Helper::currencyIdrFormat($prices) ?? null,
'price' => $prices ? Helper::currencyIdrFormat($prices) : null,
]),
$this->mergeWhen($this->name, [
'title' => 'Spesialis ' . $this->name,