Exams.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <?php
  2. namespace app\admin\model\teacher;
  3. use app\admin\model\Report;
  4. use think\Model;
  5. use think\Db;
  6. use traits\model\SoftDelete;
  7. class Exams extends Model
  8. {
  9. use SoftDelete;
  10. // 表名
  11. protected $name = 'real_exam';
  12. // 自动写入时间戳字段
  13. protected $autoWriteTimestamp = 'int';
  14. // 定义时间戳字段名
  15. protected $createTime = 'createtime';
  16. protected $updateTime = 'updatetime';
  17. protected $deleteTime = 'deletetime';
  18. // 追加属性
  19. protected $append = [
  20. 'sim_type_text',
  21. 'simtype_abbr_text',
  22. 'fault_names',
  23. 'xianxiang_names',
  24. 'yuanyin_names',
  25. 'buwei_names',
  26. 'fangfa_names',
  27. 'qudui_text'
  28. ];
  29. protected static function init()
  30. {
  31. self::beforeUpdate(function ($row) {
  32. if(!empty($row['createtime'])){
  33. $pk = $row->getPk();
  34. $create_time = date('Y-m-d H:i:s',$row['createtime']);
  35. $update_time = date('Y-m-d H:i:s',$row['updatetime']);
  36. $row->getQuery()->where($pk, $row[$pk])->update(['create_time' => $create_time,'update_time'=>$update_time]);
  37. }
  38. });
  39. self::afterInsert(function ($row) {
  40. if(!empty($row['createtime'])){
  41. $pk = $row->getPk();
  42. $create_time = date('Y-m-d H:i:s',$row['createtime']);
  43. $update_time = date('Y-m-d H:i:s',$row['updatetime']);
  44. $row->getQuery()->where($pk, $row[$pk])->update(['create_time' => $create_time,'update_time'=>$update_time]);
  45. }
  46. });
  47. }
  48. public function getSimTypeTextAttr($value, $data)
  49. {
  50. $sim_type_text = '';
  51. if($data['sim_type']=='0001'){
  52. $sim_type_text = 'FZD04B型侦毒器';
  53. }else if ($data['sim_type']=='0002'){
  54. $sim_type_text = 'FZB006型毒剂报警器';
  55. }else if ($data['sim_type']=='0003'){
  56. $sim_type_text = '防化兵用毒剂报警器';
  57. }
  58. return $sim_type_text;
  59. }
  60. public function getSimtypeAbbrTextAttr($value, $data)
  61. {
  62. $sim_type_text = '';
  63. if($data['sim_type']=='0001'){
  64. $sim_type_text = 'FZD04B型';
  65. }else if ($data['sim_type']=='0002'){
  66. $sim_type_text = 'FZB006型';
  67. }else if ($data['sim_type']=='0003'){
  68. $sim_type_text = '防化兵';
  69. }
  70. return $sim_type_text;
  71. }
  72. public function getFaultNamesAttr($value, $data)
  73. {
  74. $fault_name = '';
  75. $fault_ids = \app\admin\model\teacher\ExamsFault::where(['exam_id'=>$data['exam_id'],'flag'=>1])->column('fault_id');
  76. $fault_name = Db::name('fault')->where('fault_id','in',$fault_ids)->column('name');
  77. return !empty($fault_name)? implode(',',$fault_name):'';
  78. }
  79. //现象
  80. public function getXianxiangNamesAttr($value, $data)
  81. {
  82. $xianxian_content = Db::name('real_exam_score')->where('exam_id',$data['exam_id'])->value('xianxian_content');
  83. $xianxiang_name = !empty($xianxian_content) ? json_decode($xianxian_content,true):'';
  84. return $xianxiang_name??'';
  85. }
  86. //原因
  87. public function getYuanyinNamesAttr($value, $data)
  88. {
  89. $yuanyin_content = Db::name('real_exam_score')->where('exam_id',$data['exam_id'])->value('yuanyin_content');
  90. $yuanyin_name = !empty($yuanyin_content) ? json_decode($yuanyin_content,true):'';
  91. return $yuanyin_name??'';
  92. }
  93. //部位
  94. public function getBuweiNamesAttr($value, $data)
  95. {
  96. $buwei_content = Db::name('real_exam_score')->where('exam_id',$data['exam_id'])->value('buwei_content');
  97. $buwei_name = !empty($buwei_content) ? json_decode($buwei_content,true):'';
  98. return $buwei_name??'';
  99. }
  100. //方法
  101. public function getFangfaNamesAttr($value, $data)
  102. {
  103. $fangfa_content = Db::name('real_exam_score')->where('exam_id',$data['exam_id'])->value('fangfa_content');
  104. $yuanyin_name = !empty($fangfa_content) ? json_decode($fangfa_content,true):'';
  105. return $fangfa_name??'';
  106. }
  107. //区队
  108. public function getQuduiTextAttr($value, $data)
  109. {
  110. $str = '';
  111. $qudui_name = Db::name('department')->where('id',$data['user_depart_id'])->value('name');
  112. if(!empty($qudui_name)){
  113. $str = $qudui_name;
  114. }
  115. return $str??'';
  116. }
  117. public function collection() {
  118. return $this->belongsTo('Collection', 'exam_collection_id');
  119. }
  120. public function fault(){
  121. return $this->hasMany('app\admin\model\teacher\ExamsFault','exam_id','exam_id');
  122. }
  123. }