Exams.php 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  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. ];
  28. protected static function init()
  29. {
  30. self::beforeUpdate(function ($row) {
  31. if(!empty($row['createtime'])){
  32. $pk = $row->getPk();
  33. $create_time = date('Y-m-d H:i:s',$row['createtime']);
  34. $update_time = date('Y-m-d H:i:s',$row['updatetime']);
  35. $row->getQuery()->where($pk, $row[$pk])->update(['create_time' => $create_time,'update_time'=>$update_time]);
  36. }
  37. });
  38. self::afterInsert(function ($row) {
  39. if(!empty($row['createtime'])){
  40. $pk = $row->getPk();
  41. $create_time = date('Y-m-d H:i:s',$row['createtime']);
  42. $update_time = date('Y-m-d H:i:s',$row['updatetime']);
  43. $row->getQuery()->where($pk, $row[$pk])->update(['create_time' => $create_time,'update_time'=>$update_time]);
  44. }
  45. });
  46. }
  47. public function getSimTypeTextAttr($value, $data)
  48. {
  49. $sim_type_text = '';
  50. if($data['sim_type']=='0001'){
  51. $sim_type_text = 'FZD04B型侦毒器';
  52. }else if ($data['sim_type']=='0002'){
  53. $sim_type_text = 'FZB006型毒剂报警器';
  54. }else if ($data['sim_type']=='0003'){
  55. $sim_type_text = '防化兵用毒剂报警器';
  56. }
  57. return $sim_type_text;
  58. }
  59. public function getSimtypeAbbrTextAttr($value, $data)
  60. {
  61. $sim_type_text = '';
  62. if($data['sim_type']=='0001'){
  63. $sim_type_text = 'FZD04B型';
  64. }else if ($data['sim_type']=='0002'){
  65. $sim_type_text = 'FZB006型';
  66. }else if ($data['sim_type']=='0003'){
  67. $sim_type_text = '防化兵';
  68. }
  69. return $sim_type_text;
  70. }
  71. public function getFaultNamesAttr($value, $data)
  72. {
  73. $fault_name = '';
  74. $fault_ids = \app\admin\model\teacher\ExamsFault::where(['exam_id'=>$data['exam_id'],'flag'=>1])->column('fault_id');
  75. $fault_name = Db::name('fault')->where('fault_id','in',$fault_ids)->column('name');
  76. return !empty($fault_name)? implode(',',$fault_name):'';
  77. }
  78. //现象
  79. public function getXianxiangNamesAttr($value, $data)
  80. {
  81. $xianxian_content = Db::name('real_exam_score')->where('exam_id',$data['exam_id'])->value('xianxian_content');
  82. $xianxiang_name = !empty($xianxian_content) ? json_decode($xianxian_content,true):'';
  83. return $xianxiang_name??'';
  84. }
  85. //原因
  86. public function getYuanyinNamesAttr($value, $data)
  87. {
  88. $yuanyin_content = Db::name('real_exam_score')->where('exam_id',$data['exam_id'])->value('yuanyin_content');
  89. $yuanyin_name = !empty($yuanyin_content) ? json_decode($yuanyin_content,true):'';
  90. return $yuanyin_name??'';
  91. }
  92. //部位
  93. public function getBuweiNamesAttr($value, $data)
  94. {
  95. $buwei_content = Db::name('real_exam_score')->where('exam_id',$data['exam_id'])->value('buwei_content');
  96. $buwei_name = !empty($buwei_content) ? json_decode($buwei_content,true):'';
  97. return $buwei_name??'';
  98. }
  99. //方法
  100. public function getFangfaNamesAttr($value, $data)
  101. {
  102. $fangfa_content = Db::name('real_exam_score')->where('exam_id',$data['exam_id'])->value('fangfa_content');
  103. $yuanyin_name = !empty($fangfa_content) ? json_decode($fangfa_content,true):'';
  104. return $fangfa_name??'';
  105. }
  106. public function collection() {
  107. return $this->belongsTo('Collection', 'exam_collection_id');
  108. }
  109. public function fault(){
  110. return $this->hasMany('app\admin\model\teacher\ExamsFault','exam_id','exam_id');
  111. }
  112. }