Level.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. <?php
  2. namespace app\admin\controller\commission;
  3. use app\common\controller\Backend;
  4. use app\common\model\commission\Level as LevelModel;
  5. use think\Db;
  6. class Level extends Backend
  7. {
  8. protected $noNeedRight = ['select'];
  9. protected $model = null;
  10. /**
  11. * 快速搜索时执行查找的字段
  12. */
  13. protected $searchFields = 'level,name';
  14. /**
  15. * 是否是关联查询
  16. */
  17. protected $relationSearch = false;
  18. public function _initialize()
  19. {
  20. parent::_initialize();
  21. $this->model = new LevelModel();
  22. // 确保默认等级存在
  23. $this->ensureDefaultLevel();
  24. }
  25. /**
  26. * 查看
  27. */
  28. public function index()
  29. {
  30. if (!$this->request->isAjax()) {
  31. return $this->view->fetch();
  32. }
  33. list($where, $sort, $order, $offset, $limit) = $this->buildparams();
  34. $list = $this->model
  35. ->where($where)
  36. ->order($sort, $order)
  37. ->paginate($limit);
  38. $result = array("total" => $list->total(), "rows" => $list->items());
  39. return json($result);
  40. }
  41. /**
  42. * 确保默认等级存在
  43. */
  44. private function ensureDefaultLevel()
  45. {
  46. $defaultLevel = $this->model->where('level', 1)->find();
  47. if (!$defaultLevel) {
  48. $data = [
  49. 'name' => '默认等级',
  50. 'level' => 1,
  51. 'commission_rules' => json_encode([
  52. 'commission_1' => '0.00',
  53. 'commission_2' => '0.00',
  54. 'commission_3' => '0.00'
  55. ]),
  56. 'upgrade_type' => 0,
  57. 'upgrade_rules' => json_encode([])
  58. ];
  59. $this->model->save($data);
  60. }
  61. }
  62. /**
  63. * 添加
  64. */
  65. public function add()
  66. {
  67. if (!$this->request->isAjax()) {
  68. return $this->view->fetch();
  69. }
  70. $params = $this->request->post("row/a");
  71. if (empty($params)) {
  72. $this->error(__('Parameter %s can not be empty', 'row'));
  73. }
  74. // 只保留允许的字段
  75. $params = array_intersect_key($params, array_flip(['level', 'name', 'image', 'commission_rules']));
  76. // 处理JSON字段
  77. if (isset($params['commission_rules']) && is_array($params['commission_rules'])) {
  78. $params['commission_rules'] = json_encode($params['commission_rules']);
  79. }
  80. // 设置默认值
  81. $params['upgrade_type'] = 0;
  82. $params['upgrade_rules'] = null;
  83. $this->model->save($params);
  84. $this->success('保存成功', null, $this->model);
  85. }
  86. /**
  87. * 编辑
  88. *
  89. * @param $id
  90. */
  91. public function edit($ids = null)
  92. {
  93. $row = $this->model->where('level', $ids)->find();
  94. if (!$row) {
  95. $this->error(__('No Results were found'));
  96. }
  97. if (!$this->request->isAjax()) {
  98. // 解析commission_rules JSON数据供编辑页面使用
  99. if ($row['commission_rules']) {
  100. if (is_string($row['commission_rules'])) {
  101. // 如果是字符串,则解码
  102. $commission_rules = json_decode($row['commission_rules'], true);
  103. if ($commission_rules) {
  104. $row['commission_rules'] = $commission_rules;
  105. }
  106. } elseif (is_array($row['commission_rules'])) {
  107. // 如果已经是数组,直接使用
  108. // commission_rules 已经是数组了,无需处理
  109. }
  110. }
  111. $this->view->assign("row", $row);
  112. return $this->view->fetch('add');
  113. }
  114. $params = $this->request->post("row/a");
  115. if (empty($params)) {
  116. $this->error(__('Parameter %s can not be empty', 'row'));
  117. }
  118. // 只保留允许的字段
  119. $params = array_intersect_key($params, array_flip(['level', 'name', 'image', 'commission_rules']));
  120. // 如果是编辑1级(默认等级),不允许修改level字段
  121. if ($row['level'] == 1) {
  122. unset($params['level']); // 移除level参数,保持原值
  123. }
  124. // 处理JSON字段
  125. if (isset($params['commission_rules']) && is_array($params['commission_rules'])) {
  126. $params['commission_rules'] = json_encode($params['commission_rules']);
  127. }
  128. $result = $this->model->where('level', $ids)->update($params);
  129. if ($result) {
  130. $this->success('更新成功', null, $result);
  131. } else {
  132. $this->error('更新失败');
  133. }
  134. }
  135. /**
  136. * 详情
  137. *
  138. * @param $id
  139. * @return \think\Response
  140. */
  141. public function detail($id)
  142. {
  143. $detail = $this->model->get($id);
  144. if (!$detail) {
  145. $this->error(__('No Results were found'));
  146. }
  147. $this->success('等级详情', null, $detail);
  148. }
  149. /**
  150. * 删除
  151. *
  152. * @param $id
  153. * @return \think\Response
  154. */
  155. public function delete($id)
  156. {
  157. if (empty($id)) {
  158. $this->error(__('Parameter %s can not be empty', 'id'));
  159. }
  160. $result = Db::transaction(function () use ($id) {
  161. return $this->model->where('level', $id)->delete();
  162. });
  163. if ($result) {
  164. $this->success('删除成功', null, $result);
  165. } else {
  166. $this->error(__('No rows were deleted'));
  167. }
  168. }
  169. // 选择分销商等级
  170. public function select()
  171. {
  172. if (!$this->request->isAjax()) {
  173. return $this->view->fetch();
  174. }
  175. $data = $this->model->order('level', 'asc')->field('level, name, image, commission_rules')->select();
  176. // 解码JSON字段
  177. foreach ($data as &$item) {
  178. if (!empty($item['commission_rules'])) {
  179. $item['commission_rules'] = json_decode($item['commission_rules'], true);
  180. }
  181. }
  182. $this->success('选择等级', null, $data);
  183. }
  184. }