You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
101 lines
4.6 KiB
101 lines
4.6 KiB
<?php
|
|
// +----------------------------------------------------------------------
|
|
// | 天诚科技 [ 刘海东 17600099397赋能开发者,助力企业发展 ]
|
|
// +----------------------------------------------------------------------
|
|
// | Copyright (c) 2016~2020 https://www.tczxkj.com All rights reserved.
|
|
// +----------------------------------------------------------------------
|
|
// | Licensed 该系统并不是自由软件,未经许可不能去掉相关版权
|
|
// +----------------------------------------------------------------------
|
|
// | Author:甘肃天诚志信电子商务有限公司 刘海东 联系电话维系17600099397
|
|
// +----------------------------------------------------------------------
|
|
|
|
namespace app\wap\model\topic;
|
|
|
|
use traits\ModelTrait;
|
|
use basic\ModelBasic;
|
|
use app\wap\model\topic\ExaminationTestRecord;
|
|
use app\wap\model\topic\ExaminationWrongBank;
|
|
use app\wap\model\topic\TestPaper;
|
|
use app\wap\model\topic\TestPaperObtain;
|
|
use app\admin\model\questions\TestPaperScoreGrade;
|
|
use app\wap\model\wap\Clearance;
|
|
|
|
use service\ClearanceService;
|
|
|
|
/**
|
|
* 用户考试记录 Model
|
|
* Class ExaminationRecord
|
|
*/
|
|
class ExaminationRecord extends ModelBasic
|
|
{
|
|
use ModelTrait;
|
|
|
|
/**添加考试记录
|
|
* @param $id
|
|
* @param $type
|
|
* @param $uid
|
|
*/
|
|
public static function addExaminationRecord($id, $type, $uid, $txamination_time)
|
|
{
|
|
$data['test_id'] = $id;
|
|
$data['type'] = $type;
|
|
$data['uid'] = $uid;
|
|
$data['add_time'] = time();
|
|
if ($type == 2) {
|
|
$data['start_time'] = time();
|
|
$data['end_time'] = bcadd(time(), bcmul($txamination_time, 60, 0), 0);
|
|
}
|
|
return self::insertGetId($data);
|
|
}
|
|
|
|
/**清除上次考试结果
|
|
* @param $id
|
|
* @param $type
|
|
* @param $uid
|
|
*/
|
|
public static function clearLastExamResults($id, $type, $uid)
|
|
{
|
|
$record = self::where(['test_id' => $id, 'type' => $type, 'uid' => $uid])->order('id desc')->find();
|
|
if (!$record) return true;
|
|
$testCount = ExaminationTestRecord::where(['e_id' => $record['id'], 'type' => $record['type']])->count();
|
|
if (!$testCount) return true;
|
|
self::where(['test_id' => $id, 'type' => $type, 'uid' => $uid, 'is_submit' => 0])->update(['is_submit' => 1]);
|
|
$res = ExaminationTestRecord::where(['e_id' => $record['id'], 'type' => $record['type']])->delete();
|
|
return $res;
|
|
}
|
|
|
|
/**提交考试记录
|
|
* @param $data
|
|
* @param $uid
|
|
*/
|
|
public static function submitExaminationRecord($data, $uid)
|
|
{
|
|
$record = self::where(['id' => $data['examination_id'], 'type' => $data['type'], 'uid' => $uid])->find();
|
|
if (!$record || $record['is_submit']) return self::setErrorInfo('记录不存在或已提交!');
|
|
$yes_questions = ExaminationTestRecord::where(['e_id' => $record['id'], 'type' => $record['type'], 'is_correct' => 2])->count();
|
|
$wrong_question = ExaminationTestRecord::where(['e_id' => $record['id'], 'type' => $record['type'], 'is_correct' => 1])->count();
|
|
$testPaper = TestPaper::where(['id' => $record['test_id'], 'is_show' => 1, 'is_del' => 0])->field('is_score,item_number')->find();
|
|
$array['accuracy'] = bcmul(bcdiv($yes_questions, $testPaper['item_number'], 2), 100, 0);
|
|
$array['yes_questions'] = $yes_questions;
|
|
$array['wrong_question'] = $wrong_question;
|
|
$array['is_submit'] = 1;
|
|
$array['end_time'] = time();
|
|
$array['duration'] = $data['duration'];
|
|
$array['score'] = ExaminationTestRecord::where(['e_id' => $record['id'], 'type' => $record['type'], 'is_correct' => 2])->sum('score');
|
|
$array['grade'] = TestPaperScoreGrade::getTestPaperScoreGrade($record['test_id'], $array['score']);
|
|
$res = self::edit($array, $record['id']);
|
|
//记录打卡记录
|
|
$clearance = Clearance::where('id', $data['special_id'] ?? 0)->find();
|
|
if ($clearance) {
|
|
ClearanceService::clockIn($uid, $clearance['subject_id'], 2, $clearance['id'], $data['examination_id'], 0, 0, $array['score'], $array['accuracy'], $array['end_time'] - $record['start_time']);
|
|
}
|
|
|
|
|
|
if (!$res) return self::setErrorInfo('记录修改错误!');
|
|
$res1 = ExaminationWrongBank::addWrongBank($record['id'], $record['test_id'], $record['type'], $uid);
|
|
$res2 = TestPaper::PreExercisesWhere()->where(['id' => $record['test_id']])->setInc('answer');
|
|
$res3 = TestPaperObtain::where(['test_id' => $record['test_id'], 'type' => $data['type'], 'uid' => $uid, 'is_del' => 0])->setInc('number');
|
|
if ($res && $res1 && $res2 && $res3) return true;
|
|
else return false;
|
|
}
|
|
}
|
|
|