QuestionType.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. <?php
  2. namespace app\admin\controller;
  3. use app\BaseController;
  4. use app\admin\model\QuestionType as QuestionTypeModel;
  5. use Exception;
  6. /**
  7. * 问题类别
  8. */
  9. class QuestionType extends BaseController
  10. {
  11. /**
  12. */
  13. function list()
  14. {
  15. try {
  16. $params = $this->request->param();
  17. $page = $params['page'] ?? 1;
  18. $limit = $params['limit'] ?? 15;
  19. $language_code = $params['language_code'] ?? $this->lang;
  20. $query = QuestionTypeModel::where('language_code', $language_code);
  21. if (!empty($params['name'])) {
  22. $query = $query->where('name', 'like', '%'.$params['name'].'%');
  23. }
  24. if (isset($params['status']) && $params['status'] != '') {
  25. $query = $query->where('status', $params['status']);
  26. }
  27. $count = $query->count();
  28. $list = $query->order('id','desc')
  29. ->limit($limit)
  30. ->page($page)
  31. ->select();
  32. } catch (Exception $e) {
  33. return $this->error($e->getMessage());
  34. }
  35. return $this->success(['count' => $count, 'list' => $list]);
  36. }
  37. //新增/编辑
  38. public function update()
  39. {
  40. try {
  41. $params = $this->request->param();
  42. if (empty($params['name'])) {
  43. return $this->error('请输入类别名称');
  44. }
  45. $id = $this->request->param('id',0);
  46. $language_code = $params['language_code'] ?? $this->lang;
  47. $exists = QuestionTypeModel::where('name', $params['name'])->where('language_code', $language_code)->find();
  48. if ($exists ) {
  49. if (!$id || $id != $exists->id) {
  50. return $this->error('类别已存在');
  51. }
  52. }
  53. if (empty($id)) {
  54. $type = new QuestionTypeModel();
  55. } else {
  56. $type = QuestionTypeModel::where('id', $id)->find();
  57. if (!$type) {
  58. return $this->error('类别不存在');
  59. }
  60. }
  61. $type->name = $params['name'];
  62. $type->language_code = $language_code;
  63. $type->save();
  64. } catch (Exception $e) {
  65. return $this->error($e->getMessage());
  66. }
  67. return $this->success([], '操作成功');
  68. }
  69. //删除
  70. public function delete()
  71. {
  72. try {
  73. $id = $this->request->param('id',0);
  74. $info = QuestionTypeModel::where('id', $id)->find();
  75. if (!$info) {
  76. return $this->error('类别不存在');
  77. }
  78. $info->delete();
  79. } catch (Exception $e) {
  80. return $this->error($e->getMessage());
  81. }
  82. return $this->success([],'删除成功');
  83. }
  84. }