ArticleCategoryService.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. <?php
  2. namespace App\Services\Common;
  3. use App\Models\ArticleCategoryModel;
  4. use App\Services\BaseService;
  5. use Illuminate\Support\Facades\DB;
  6. /**
  7. * 文章分类管理-服务类
  8. * @author laravel开发员
  9. * @since 2020/11/11
  10. * Class ArticleCategoryService
  11. * @package App\Services\Common
  12. */
  13. class ArticleCategoryService extends BaseService
  14. {
  15. /**
  16. * 构造函数
  17. * @author laravel开发员
  18. * @since 2020/11/11
  19. * ArticleCategoryService constructor.
  20. */
  21. public function __construct()
  22. {
  23. $this->model = new ArticleCategoryModel();
  24. }
  25. /**
  26. * 获取分类数据列表(树形结构)
  27. */
  28. public function getDataList($params, $pageSize = 15)
  29. {
  30. $query = $this->model->where('mark', 1);
  31. // 按类型过滤
  32. if (!empty($params['type'])) {
  33. $query->where('type', $params['type']);
  34. }
  35. // 按状态过滤
  36. if (isset($params['status']) && $params['status'] !== '') {
  37. $query->where('status', $params['status']);
  38. }
  39. // 按名称搜索
  40. if (!empty($params['keyword'])) {
  41. $query->where('name', 'like', "%{$params['keyword']}%");
  42. }
  43. $items = $query->orderBy('sort', 'desc')
  44. ->orderBy('id', 'desc')
  45. ->get()
  46. ->toArray();
  47. // 处理图片字段
  48. foreach ($items as &$item) {
  49. if (!empty($item['icon'])) {
  50. $item['icon'] = get_image_url($item['icon']);
  51. }
  52. $item['create_time'] = $item['create_time'] ? datetime($item['create_time'], 'Y-m-d H:i:s') : '';
  53. $item['update_time'] = $item['update_time'] ? datetime($item['update_time'], 'Y-m-d H:i:s') : '';
  54. }
  55. // 构建树形结构
  56. $tree = $this->buildTree($items);
  57. return [
  58. 'pageSize' => $pageSize,
  59. 'total' => count($items),
  60. 'list' => $tree
  61. ];
  62. }
  63. /**
  64. * 构建树形结构
  65. */
  66. private function buildTree($items, $pid = 0)
  67. {
  68. $tree = [];
  69. foreach ($items as $item) {
  70. // 确保 pid 字段存在,默认为 0
  71. $itemPid = isset($item['pid']) ? $item['pid'] : 0;
  72. if ($itemPid == $pid) {
  73. $children = $this->buildTree($items, $item['id']);
  74. if (!empty($children)) {
  75. $item['children'] = $children;
  76. }
  77. $tree[] = $item;
  78. }
  79. }
  80. return $tree;
  81. }
  82. /**
  83. * 获取分类选项列表(树形结构)
  84. * @return array
  85. */
  86. public function getOptions()
  87. {
  88. $query = $this->model->where(['status' => 1, 'mark' => 1]);
  89. // 按类型过滤
  90. $type = request()->get('type');
  91. if ($type) {
  92. $query->where('type', $type);
  93. }
  94. $datas = $query->select(['id', 'name', 'pid'])
  95. ->orderBy('sort', 'desc')
  96. ->orderBy('id', 'desc')
  97. ->get()
  98. ->toArray();
  99. // 构建树形结构
  100. return $this->buildTree($datas);
  101. }
  102. /**
  103. * 获取父级分类选项(用于选择父级分类)
  104. * @return array
  105. */
  106. public function getParentOptions()
  107. {
  108. $query = $this->model->where(['status' => 1, 'mark' => 1, 'pid' => 0]);
  109. // 按类型过滤
  110. $type = request()->get('type');
  111. if ($type) {
  112. $query->where('type', $type);
  113. }
  114. return $query->select(['id', 'name', 'pid'])
  115. ->orderBy('sort', 'desc')
  116. ->orderBy('id', 'desc')
  117. ->get()
  118. ->toArray();
  119. }
  120. /**
  121. * 检查表是否有 pid 字段
  122. * @return bool
  123. */
  124. private function checkPidFieldExists()
  125. {
  126. try {
  127. $tableName = $this->model->getTable();
  128. $columns = DB::select("SHOW COLUMNS FROM `{$tableName}` LIKE 'pid'");
  129. return !empty($columns);
  130. } catch (\Exception $e) {
  131. // 如果查询失败,假设没有 pid 字段
  132. return false;
  133. }
  134. }
  135. /**
  136. * 添加或编辑分类
  137. */
  138. public function edit()
  139. {
  140. $data = request()->all();
  141. // 处理图标字段
  142. if (!empty($data['icon'])) {
  143. $data['icon'] = get_image_path(trim($data['icon']));
  144. }
  145. $id = $data['id'] ?? 0;
  146. $data['pid'] = empty($data['pid']) ? 0 : $data['pid'];
  147. // 默认字段处理
  148. $data['update_time'] = time();
  149. if (!$id) {
  150. $data['create_time'] = time();
  151. }
  152. return parent::edit($data);
  153. }
  154. }