SampleBus.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. <?php
  2. /**
  3. *
  4. *User:Administrator
  5. *Date:2021/10/14
  6. */
  7. namespace app\api\business;
  8. use app\api\model\Ccjc;
  9. use app\api\model\Cyd;
  10. use app\api\model\TestModel;
  11. use app\api\model\UnitProduction;
  12. use app\api\model\UnitSample;
  13. use app\api\model\UnitTest;
  14. use app\common\lib\Arr;
  15. use app\common\lib\auth\JwtAuth;
  16. class SampleBus
  17. {
  18. private $uid;
  19. public function __construct()
  20. {
  21. $JwtAuth = JwtAuth::getInstance();
  22. $this->uid = $JwtAuth->getUid();
  23. }
  24. public function getCydDetail($sample_id)
  25. {
  26. $result = (new Cyd())->getCydDetailBySampleID($sample_id);
  27. return $result;
  28. }
  29. public function selectSampleList($data)
  30. {
  31. $uid = $this->uid;
  32. $where=[
  33. ['cyd.task_id', '=', $data['task_id']],//这里绑定成cyd.task_id进行查询
  34. ['uid', '=', $uid]
  35. ];
  36. if ($data['sample_name']!='') $where[]=['sample_name', 'LIKE', '%'.$data['sample_name'].'%'];//样品名称
  37. if ($data['sample_id']!='') $where[]=['sample_id', 'LIKE', '%'.$data['sample_id'].'%'];//样品编码
  38. if ($data['sample_ground']!='') $where[]=['sample_ground', 'LIKE', '%'.$data['sample_ground'].'%'];//抽样场所
  39. //bear-抽样单位,report-报告单位,check-检测单位
  40. if($data['unit_test_name']!='') $where[]=['unit_test_name','LIKE','%'.$data['unit_test_name'].'%'];//受检单位名称
  41. if($data['unit_sample_name']!='') $where[]=['unit_sample_name','LIKE','%'.$data['unit_sample_name'].'%'];//抽样单位名称
  42. if($data['unit_production_name']!='') $where[]=['unit_production_name','LIKE','%'.$data['unit_production_name'].'%'];//生产单位名称
  43. if($data['sample_data']!='') $where[]=['sample_date','=',$data['sample_data']];//抽样日期
  44. $result = (new Cyd())->selectSampleListByTaskIdAndUid($where, $data['pageNum'], $data['pageSize']);
  45. $count = (new Cyd())->countSampleListByTaskIdAndUid($where);
  46. return ['rows'=>$result,'total'=>$count];
  47. }
  48. public function getSampleObj($task_id,$under_task_id)
  49. {
  50. $model_id = (new Ccjc())->getTaskInfoByTaskID($task_id)['test_model_id'];
  51. $data = (new TestModel())->getProductInfo($model_id);
  52. $result=(new Arr())->Arr_columns($data, 'product_name,product_id');
  53. return $result;
  54. }
  55. public function createSampleId($task_id)
  56. {
  57. $task_class = (new Ccjc())->getTaskInfoByTaskID($task_id)['task_class'];
  58. $count = (new Cyd())->countSampleCreateID();
  59. if ($task_class=="例行监测") {
  60. $id['id'] = 'LXJC' . date('Y') . date('m') . date('d') . date('H') . date('m') . str_pad(($count + 1), 4, 0, STR_PAD_LEFT);
  61. }
  62. if ($task_class=='专项监测'){
  63. $id['id'] = 'ZXJC'.date('Y').date('m').date('d').date('H').date('m').str_pad(($count+1),4,0,STR_PAD_LEFT);
  64. }
  65. return $id;
  66. }
  67. public function createSample($unit_test,$unit_production,$unit_sample,$cyd_data)
  68. {
  69. //写入抽样单信息,并返回抽样单cyd ID
  70. $cyd_id = (new Cyd())->createSample($cyd_data);
  71. //赋值cydID
  72. $unit_test['cyd_id']=$unit_production['cyd_id']=$unit_sample['cyd_id']=$cyd_id;
  73. //写入受检单位信息,并返回自增id
  74. $unit_test_id = (new UnitTest())->insertUnitTestDataGetId($unit_test);
  75. //写入生产单位信息,并返回自增id
  76. $unit_production_id = (new UnitProduction())->insertUnitProductionDataGetId($unit_production);
  77. //写入抽样单位信息,并返回自增id
  78. $unit_sample_id=(new UnitSample())->insertUnitSampleDataGetId($unit_sample);
  79. //将各种id写入cyd
  80. $cyd_id_data = [
  81. 'uid' => $this->uid,
  82. 'test_id' => '',//检测单位id
  83. 'units_id' => $unit_test_id,//受检单位id
  84. 'product_unit' => $unit_production_id,//生产单位id
  85. 'sample_unit' => $unit_sample_id,//抽样单位id
  86. ];
  87. $result = (new Cyd())->updateCydDataByID($cyd_id,$cyd_id_data);
  88. return $result;
  89. }
  90. }