ClientBDTDevice.php 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738
  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 supplyOrders(){
  13. return $this->hasMany(SupplyOrder::class, 'client_bdt_device_id', 'id');
  14. }
  15. public function mostRecentMeasurement() {
  16. return $this->hasOne(ClientBDTMeasurement::class, 'id', 'most_recent_client_bdt_measurement_id');
  17. }
  18. public function lastDeviceMeasurement() {
  19. return BDTMeasurement::select('bdt_measurement.created_at', 'measurement.label', 'measurement.sbp_mm_hg', 'measurement.dbp_mm_hg', 'measurement.numeric_value')
  20. ->join('client_bdt_measurement', 'client_bdt_measurement.bdt_measurement_id', '=', 'bdt_measurement.id')
  21. ->join('measurement', 'measurement.client_bdt_measurement_id', '=', 'client_bdt_measurement.id')
  22. ->where('bdt_measurement.is_cellular_zero', '<>', true)
  23. ->whereNotNull('bdt_measurement.ts')
  24. ->where('client_bdt_measurement.client_id', $this->client_id)
  25. ->where('bdt_measurement.imei', $this->device->imei)
  26. ->orderBy('bdt_measurement.created_at', 'DESC')
  27. ->first();
  28. }
  29. }