TrainingCourseLogic.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  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\logic\BaseLogic;
  17. use think\facade\Db;
  18. /**
  19. * TrainingCourse逻辑
  20. * Class TrainingCourseLogic
  21. * @package app\adminapi\logic
  22. */
  23. class TrainingCourseLogic extends BaseLogic
  24. {
  25. /**
  26. * @notes 添加
  27. * @param array $params
  28. * @return bool
  29. * @author likeadmin
  30. * @date 2025/02/14 17:37
  31. */
  32. public static function add(array $params): bool
  33. {
  34. if($params['subclass']) $params['subclass'] = end($params['subclass']);
  35. Db::startTrans();
  36. try {
  37. TrainingCourse::create([
  38. 'course_name' => $params['course_name'],
  39. 'course_picture' => $params['course_picture'],
  40. 'course_url' => $params['course_url'],
  41. 'course_lock' => $params['course_lock'],
  42. 'course_length' => $params['course_length'],
  43. 'course_question_setting' => self::configureReservedField($params['course_question_setting']??[]),
  44. 'course_question_score' => $params['course_question_score'],
  45. 'subclass' => $params['subclass']??0,
  46. 'randomly_question' => $params['randomly_question']??0,
  47. 'randomly_num' => $params['randomly_num']??0,
  48. ]);
  49. Db::commit();
  50. return true;
  51. } catch (\Exception $e) {
  52. Db::rollback();
  53. self::setError($e->getMessage());
  54. return false;
  55. }
  56. }
  57. /**
  58. * @notes 编辑
  59. * @param array $params
  60. * @return bool
  61. * @author likeadmin
  62. * @date 2025/02/14 17:37
  63. */
  64. public static function edit(array $params): bool
  65. {
  66. Db::startTrans();
  67. try {
  68. TrainingCourse::where('id', $params['id'])->update([
  69. 'course_name' => $params['course_name'],
  70. 'course_picture' => $params['course_picture'],
  71. 'course_url' => $params['course_url'],
  72. 'course_lock' => $params['course_lock'],
  73. 'course_length' => $params['course_length'],
  74. 'course_question_setting' => json_encode(self::configureReservedField($params['course_question_setting']??[])),
  75. 'course_question_score' => $params['course_question_score'],
  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/14 17:37
  91. */
  92. public static function delete(array $params): bool
  93. {
  94. return TrainingCourse::destroy($params['id']);
  95. }
  96. /**
  97. * @notes 获取详情
  98. * @param $params
  99. * @return array
  100. * @author likeadmin
  101. * @date 2025/02/14 17:37
  102. */
  103. public static function detail($params): array
  104. {
  105. return TrainingCourse::findOrEmpty($params['id'])->toArray();
  106. }
  107. public static function configureReservedField($data): array
  108. {
  109. foreach ($data as $key => &$item) {
  110. $data[$key]['block_key'] = $key+1;
  111. $item['select_value'] = (int)$item['select_value'];
  112. }
  113. return $data??[];
  114. }
  115. }