tinyqc/app/Models/ResultModel.php

73 lines
2.4 KiB
PHP

<?php
namespace App\Models;
use App\Models\BaseModel;
class ResultModel extends BaseModel
{
protected $table = 'results';
protected $primaryKey = 'result_id';
protected $useAutoIncrement = true;
protected $returnType = 'array';
protected $useSoftDeletes = true;
protected $useTimestamps = true;
protected $allowedFields = ['control_ref_id', 'test_ref_id', 'resdate', 'resvalue', 'rescomment'];
public function getByMonth($controlId, $testId, $yearMonth)
{
$startDate = $yearMonth . '-01';
$endDate = $yearMonth . '-31';
$builder = $this->db->table('results');
$builder->select('*');
$builder->where('control_ref_id', $controlId);
$builder->where('test_ref_id', $testId);
$builder->where('resdate >=', $startDate);
$builder->where('resdate <=', $endDate);
$builder->orderBy('resdate', 'ASC');
return $builder->get()->getResultArray();
}
public function getByControlMonth($controlId, $yearMonth)
{
$startDate = $yearMonth . '-01';
$endDate = $yearMonth . '-31';
$builder = $this->db->table('results');
$builder->select('*');
$builder->where('control_ref_id', $controlId);
$builder->where('resdate >=', $startDate);
$builder->where('resdate <=', $endDate);
return $builder->get()->getResultArray();
}
public function saveResult($data)
{
$builder = $this->db->table('results');
$existing = $builder->select('*')
->where('control_ref_id', $data['control_ref_id'])
->where('test_ref_id', $data['test_ref_id'])
->where('resdate', $data['resdate'])
->get()
->getRowArray();
if ($existing) {
return $builder->where('result_id', $existing['result_id'])->update($data);
} else {
return $builder->insert($data);
}
}
public function checkExisting($controlId, $testId, $resdate)
{
$builder = $this->db->table('results');
return $builder->select('result_id')
->where('control_ref_id', $controlId)
->where('test_ref_id', $testId)
->where('resdate', $resdate)
->get()
->getRowArray();
}
}