ClientBDTDevice.php 1.1 KB

1234567891011121314151617181920212223242526272829
  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 lastDeviceMeasurement() {
  13. return BDTMeasurement::select('bdt_measurement.created_at', 'measurement.label', 'measurement.sbp_mm_hg', 'measurement.dbp_mm_hg', 'measurement.numeric_value')
  14. ->join('client_bdt_measurement', 'client_bdt_measurement.bdt_measurement_id', '=', 'bdt_measurement.id')
  15. ->join('measurement', 'measurement.client_bdt_measurement_id', '=', 'client_bdt_measurement.id')
  16. ->where('bdt_measurement.is_cellular_zero', '<>', true)
  17. ->whereNotNull('bdt_measurement.ts')
  18. ->where('client_bdt_measurement.client_id', $this->client_id)
  19. ->where('bdt_measurement.imei', $this->device->imei)
  20. ->orderBy('bdt_measurement.created_at', 'DESC')
  21. ->first();
  22. }
  23. }