CmsSubjectRepository.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. <?php
  2. namespace App\Repositories;
  3. use App\Models\CmsSubject;
  4. use App\Models\CmsSubjectProduct;
  5. use Symfony\Component\HttpKernel\Exception\HttpException;
  6. use Dingo\Api\Http\Response;
  7. use Illuminate\Support\Facades\DB;
  8. use Illuminate\Database\QueryException;
  9. class CmsSubjectRepository {
  10. public function __construct(CmsSubject $cmsSubject,CmsSubjectProduct $cmsSubjectProduct) {
  11. $this->cmsSubject = $cmsSubject;
  12. $this->cmsSubjectProduct = $cmsSubjectProduct;
  13. }
  14. //专题列表
  15. public function index($request)
  16. {
  17. $perPage = isset($request['per_page']) ? $request['per_page'] : env('PER_PAGE');
  18. $where = [];
  19. if(isset($request['id'])){
  20. $where[] = ['id', '=', $request['id']];
  21. }
  22. if(isset($request['city_id'])){
  23. $where[] = ['city_id', '=', $request['city_id']];
  24. }
  25. if(isset($request['is_open'])){
  26. $where[] = ['is_open', '=', $request['is_open']];
  27. }
  28. return $this->cmsSubject->where($where)->orderBy('id', 'asc')->paginate($perPage);
  29. }
  30. /**
  31. * 添加专题
  32. */
  33. public function create($request)
  34. {
  35. if($this->cmsSubject->where('title', trim($request['title']))->exists()){
  36. throw new HttpException(500, '该专题已经存在');
  37. }
  38. $subject = [
  39. 'title' => $request['title'],
  40. 'city_id' => $request['city_id'],
  41. 'city_name' => $request['city_name'],
  42. 'show_type' => $request['show_type'],
  43. 'is_open' => $request['is_open'],
  44. ];
  45. $date = date('Y-m-d H:i:s');
  46. DB::beginTransaction();
  47. try{
  48. $res = $this->cmsSubject->create($subject);
  49. if ($res && $request['product_id']){
  50. $products = explode(',',$request['product_id']);
  51. $sort = explode(',',$request['sort']);
  52. $product_num = count($products);
  53. $sort_num = count($sort);
  54. if ($sort_num != $product_num){
  55. throw new HttpException(500, '请检查商品与排序数目是否对应');
  56. }
  57. $subject_product = new CmsSubjectProduct();
  58. for ($i = 0;$i < $product_num;$i++){
  59. $resert_data =[
  60. 'product_id' => $products[$i],
  61. 'sort' => $sort[$i],
  62. 'subject_id' => $res['id'],
  63. 'created_at' => $date,
  64. 'updated_at' => $date,
  65. ];
  66. $subject_product->insert($resert_data);
  67. }
  68. }
  69. DB::commit();
  70. return Response::create();
  71. }catch (QueryException $exception){
  72. DB::rollBack();
  73. return Response::create([
  74. 'message' => '添加失败,请重试',
  75. 'error' => $exception->getMessage(),
  76. 'status_code' => 500
  77. ]);
  78. }
  79. }
  80. public function edit($request)
  81. {
  82. $subject = $this->cmsSubject->find($request['id']);
  83. $subject->title = $request['title'];
  84. $subject->city_id = $request['city_id'];
  85. $subject->city_name = $request['city_name'];
  86. $subject->show_type = $request['show_type'];
  87. $subject->is_open = $request['is_open'];
  88. $date = date('Y-m-d H:i:s');
  89. DB::beginTransaction();
  90. try{
  91. $res = $subject->save();
  92. if($res && $request['product_id']) {
  93. $this->cmsSubjectProduct->where('subject_id',$subject->id)->delete();
  94. $products = explode(',', $request['product_id']);
  95. $sort = explode(',', $request['sort']);
  96. $product_num = count($products);
  97. $sort_num = count($sort);
  98. if ($sort_num != $product_num) {
  99. throw new HttpException(500, '请检查商品与排序数目是否对应');
  100. }
  101. $subject_product = new CmsSubjectProduct();
  102. for ($i = 0; $i < $product_num; $i++) {
  103. $resert_data = [
  104. 'product_id' => $products[$i],
  105. 'sort' => $sort[$i],
  106. 'subject_id' => $subject->id,
  107. 'created_at' => $date,
  108. 'updated_at' => $date,
  109. ];
  110. $subject_product->insert($resert_data);
  111. }
  112. }
  113. DB::commit();
  114. return Response::create();
  115. }catch (QueryException $exception){
  116. DB::rollBack();
  117. return Response::create([
  118. 'message' => '编辑失败,请重试',
  119. 'error' => $exception->getMessage(),
  120. 'status_code' => 500
  121. ]);
  122. }
  123. }
  124. public function delete($request)
  125. {
  126. $subject = $this->cmsSubject->find($request['id']);
  127. DB::beginTransaction();
  128. try{
  129. $res = $subject->delete();
  130. if ($res){
  131. $this->cmsSubjectProduct->where('subject_id',$subject->id)->delete();
  132. }
  133. DB::commit();
  134. return Response::create();
  135. }catch (QueryException $exception){
  136. DB::rollBack();
  137. return Response::create([
  138. 'message' => '删除失败,请重试',
  139. 'error' => $exception->getMessage(),
  140. 'status_code' => 500
  141. ]);
  142. }
  143. }
  144. public function editStatus($request)
  145. {
  146. $subject = $this->cmsSubject->find($request['id']);
  147. $subject->is_open = $request['is_open'];
  148. $subject->updated_at = date('Y-m-d H:i:s');
  149. $res = $subject->save();
  150. if (!$res) {
  151. throw new HttpException(500, '修改状态失败');
  152. }
  153. }
  154. }