TrainingWorkerTaskLogic.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeadmin快速开发前后端分离管理后台(PHP版)
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
  8. // | github下载:https://github.com/likeshop-github/likeadmin
  9. // | 访问官网:https://www.likeadmin.cn
  10. // | likeadmin团队 版权所有 拥有最终解释权
  11. // +----------------------------------------------------------------------
  12. // | author: likeadminTeam
  13. // +----------------------------------------------------------------------
  14. namespace app\adminapi\logic\training;
  15. use app\common\model\training\TrainingCourse;
  16. use app\common\model\training\TrainingTask;
  17. use app\common\model\training\TrainingWorkerCourse;
  18. use app\common\model\training\TrainingWorkerQuestion;
  19. use app\common\model\training\TrainingWorkerTask;
  20. use app\common\logic\BaseLogic;
  21. use think\facade\Db;
  22. /**
  23. * TrainingWorkerTask逻辑
  24. * Class TrainingWorkerTaskLogic
  25. * @package app\adminapi\logic
  26. */
  27. class TrainingWorkerTaskLogic extends BaseLogic
  28. {
  29. /**
  30. * @notes 添加
  31. * @param array $params
  32. * @return bool
  33. * @author likeadmin
  34. * @date 2025/02/16 13:49
  35. */
  36. public static function add(array $params): bool
  37. {
  38. Db::startTrans();
  39. try {
  40. TrainingWorkerTask::create([
  41. 'master_worker_id' => $params['master_worker_id'],
  42. 'shop_goods_id' => $params['shop_goods_id']??0,
  43. 'training_task_id' => $params['training_task_id']??0,
  44. 'lead_master_worker_id' => $params['lead_master_worker_id']??0,
  45. 'operate_status' => $params['operate_status']??0,
  46. 'task_list' => $params['task_list']??'',
  47. ]);
  48. // 添加该工程师初始化记录
  49. self::trainingCourseRecord($params['master_worker_id'],$params['training_task_id']);
  50. Db::commit();
  51. return true;
  52. } catch (\Exception $e) {
  53. Db::rollback();
  54. self::setError($e->getMessage());
  55. return false;
  56. }
  57. }
  58. /**
  59. * @notes 编辑
  60. * @param array $params
  61. * @return bool
  62. * @author likeadmin
  63. * @date 2025/02/16 13:49
  64. */
  65. public static function edit(array $params): bool
  66. {
  67. Db::startTrans();
  68. try {
  69. TrainingWorkerTask::where('id', $params['id'])->update([
  70. 'master_worker_id' => $params['master_worker_id'],
  71. 'shop_goods_id' => $params['shop_goods_id']??0,
  72. 'training_task_id' => $params['training_task_id']??0,
  73. 'lead_master_worker_id' => $params['lead_master_worker_id']??0,
  74. 'operate_status' => $params['operate_status']??0,
  75. 'task_list' => $params['task_list']?json_encode($params['task_list']):'',
  76. ]);
  77. Db::commit();
  78. return true;
  79. } catch (\Exception $e) {
  80. Db::rollback();
  81. self::setError($e->getMessage());
  82. return false;
  83. }
  84. }
  85. /**
  86. * @notes 删除
  87. * @param array $params
  88. * @return bool
  89. * @author likeadmin
  90. * @date 2025/02/16 13:49
  91. */
  92. public static function delete(array $params): bool
  93. {
  94. return TrainingWorkerTask::destroy($params['id']);
  95. }
  96. /**
  97. * @notes 获取详情
  98. * @param $params
  99. * @return array
  100. * @author likeadmin
  101. * @date 2025/02/16 13:49
  102. */
  103. public static function detail($params): array
  104. {
  105. return TrainingWorkerTask::findOrEmpty($params['id'])->toArray();
  106. }
  107. /** 培训课程初始化记录
  108. */
  109. public static function trainingCourseRecord($masterWorkerId,$training_task_id): array
  110. {
  111. $training_course_ids = json_decode(TrainingTask::where('id',$training_task_id)->value('training_course_id')??'[]',true);
  112. // 添加该工程师的所有培训课程初始化记录
  113. foreach ($training_course_ids as $course_id) {
  114. $workerCourse = TrainingWorkerCourse::create([
  115. 'master_worker_id' => $masterWorkerId,
  116. 'training_task_id' => $training_task_id,
  117. 'training_course_id' => $course_id,
  118. 'play_time' => 0,
  119. 'exam_start_time' => 0,
  120. 'exam_end_time' => 0,
  121. 'study_status' => 0,
  122. 'exam_score' => 0,
  123. ]);
  124. // 添加该工程师该课程的所有试题初始化记录
  125. //[{"block_key":1,"select_value":1,"score":"20"},{"block_key":2,"select_value":2,"score":"10"},{"block_key":3,"select_value":3,"score":"70"}]
  126. $course_question = json_decode(TrainingCourse::where('id',$course_id)->value('course_question_setting'),true);
  127. $course_question_ids = array_column($course_question,'select_value');
  128. foreach ($course_question_ids as $question_id) {
  129. $workerQuestion = TrainingWorkerQuestion::create([
  130. 'worker_course_id' => $workerCourse->id,
  131. 'questions_id' => $question_id,
  132. 'worker_answer' => '',
  133. 'exam_score' => 0
  134. ]);
  135. }
  136. }
  137. return $training_course_ids??[];
  138. }
  139. }