ClientBDTDevice.php 1.2 KB

12345678910111213141516171819202122232425262728293031323334
  1. <?php
  2. namespace App\Models;
  3. class ClientBDTDevice extends Model
  4. {
  5. protected $table = 'client_bdt_device';
  6. public function device() {
  7. return $this->hasOne(BDTDevice::class, 'id', 'device_id');
  8. }
  9. public function client() {
  10. return $this->hasOne(Client::class, 'id', 'client_id');
  11. }
  12. public function mostRecentMeasurement() {
  13. return $this->hasOne(ClientBDTMeasurement::class, 'id', 'most_recent_client_bdt_measurement_id');
  14. }
  15. public function lastDeviceMeasurement() {
  16. return BDTMeasurement::select('bdt_measurement.created_at', 'measurement.label', 'measurement.sbp_mm_hg', 'measurement.dbp_mm_hg', 'measurement.numeric_value')
  17. ->join('client_bdt_measurement', 'client_bdt_measurement.bdt_measurement_id', '=', 'bdt_measurement.id')
  18. ->join('measurement', 'measurement.client_bdt_measurement_id', '=', 'client_bdt_measurement.id')
  19. ->where('bdt_measurement.is_cellular_zero', '<>', true)
  20. ->whereNotNull('bdt_measurement.ts')
  21. ->where('client_bdt_measurement.client_id', $this->client_id)
  22. ->where('bdt_measurement.imei', $this->device->imei)
  23. ->orderBy('bdt_measurement.created_at', 'DESC')
  24. ->first();
  25. }
  26. }