CmsContentTemplateSetRepository.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. <?php
  2. namespace App\Repositories;
  3. use App\Models\CmsSubject;
  4. use Dingo\Api\Http\Response;
  5. use App\Models\CmsContentTemplate;
  6. use App\Models\CmsContentTemplateSet;
  7. use App\Models\CmsSubjectProduct;
  8. use Symfony\Component\HttpKernel\Exception\HttpException;
  9. use Illuminate\Support\Facades\DB;
  10. use Illuminate\Database\QueryException;
  11. class CmsContentTemplateSetRepository {
  12. public function __construct(CmsContentTemplateSet $cmsContentTemplateSet,CmsContentTemplate $cmsContentTemplate,CmsSubjectProduct $cmsSubjectProduct,CmsSubject $cmsSubject) {
  13. $this->cmsContentTemplateSet = $cmsContentTemplateSet;
  14. $this->cmsContentTemplate = $cmsContentTemplate;
  15. $this->cmsSubjectProduct = $cmsSubjectProduct;
  16. $this->cmsSubject = $cmsSubject;
  17. }
  18. /**
  19. * banner配置
  20. */
  21. public function bannerSet($request)
  22. {
  23. $rules = json_decode($request['rule'],true);
  24. if (is_array($rules)){
  25. if (count($rules)>10) {
  26. throw new HttpException(500, '最多只能添加10个banner海报');
  27. }
  28. $decode_floor = json_decode($request['rule'], true);
  29. $count = count($decode_floor);
  30. if ($count > 0) {
  31. for ($i = 0; $i < $count; $i++) {
  32. $subject = [
  33. 'rule' => json_encode($decode_floor[$i]),
  34. 'tpl_id' => $request['tpl_id'],
  35. 'area_type' => $request['area_type'],
  36. 'status' => 0,
  37. ];
  38. if (!$this->cmsContentTemplateSet->create($subject)) {
  39. throw new HttpException(500, '添加失败');
  40. }
  41. }
  42. }
  43. }else{
  44. throw new HttpException(500, '参数格式有误');
  45. }
  46. }
  47. /**
  48. * 专题广告配置
  49. */
  50. public function advertisementSet($request)
  51. {
  52. $subject = [
  53. 'tpl_id' => $request['tpl_id'],
  54. 'rule' => $request['rule'],
  55. 'area_type' => $request['area_type'],
  56. 'status' => 0,
  57. ];
  58. if (!$this->cmsContentTemplateSet->create($subject)) {
  59. throw new HttpException(500, '添加失败');
  60. }
  61. }
  62. /**
  63. * 商品楼层配置
  64. */
  65. public function floorSet($request)
  66. {
  67. $subject = [
  68. 'tpl_id' => $request['tpl_id'],
  69. 'rule' => $request['rule'],
  70. 'area_type' => $request['area_type'],
  71. 'status' => 0,
  72. ];
  73. if (!$this->cmsContentTemplateSet->create($subject)) {
  74. throw new HttpException(500, '添加失败');
  75. }
  76. }
  77. /**
  78. * 分类专题配置
  79. */
  80. public function categorySet($request)
  81. {
  82. $subject = [
  83. 'tpl_id' => $request['tpl_id'],
  84. 'rule' => $request['rule'],
  85. 'area_type' => $request['area_type'],
  86. 'status' => 0,
  87. ];
  88. if (!$this->cmsContentTemplateSet->create($subject)) {
  89. throw new HttpException(500, '添加失败');
  90. }
  91. }
  92. /**
  93. * 内容发布
  94. */
  95. public function release($request)
  96. {
  97. //同一个城市同一个模板(团购/菜市场) 只能有一种状态(草稿/发布),已发布的一旦被编辑把之前的直接删掉
  98. $templateSet = $this->cmsContentTemplateSet->where('tpl_id',$request['tpl_id'])->select('id','status')->get();
  99. $tem_array = $templateSet->toArray();
  100. foreach ($tem_array as $k=>$v) {
  101. if ($v['status'] == 1) {
  102. $result = $this->cmsContentTemplateSet->where('id', $v['id'])->delete();
  103. if (!$result) {
  104. return Response::create([
  105. 'message' => '删除失败,请重试',
  106. 'status_code' => 500
  107. ]);
  108. }
  109. }
  110. }
  111. $res = $this->cmsContentTemplateSet->where('tpl_id',$request['tpl_id'])->update(['status'=>1]);
  112. if (!$res){
  113. return Response::create([
  114. 'message' => '修改失败,请重试',
  115. 'status_code' => 500
  116. ]);
  117. }
  118. }
  119. /**
  120. * 内容预览
  121. */
  122. public function preview($request)
  123. {
  124. //团购首页
  125. $group_array = [];
  126. if ($request['type'] == 0){
  127. $group_array['apply_type'] ="group";
  128. $group_array['title'] ="今日团购";
  129. $group_array['content'] =[];
  130. }else{//菜市场首页
  131. $group_array['apply_type'] ="market";
  132. $group_array['title'] ="菜市场";
  133. $group_array['content'] =[];
  134. }
  135. $group_array['content'][0]['area_type'] ="banner";
  136. $banner_rule = $this->cmsContentTemplateSet->select('id','rule')->where(['tpl_id'=>$request['tpl_id'],'area_type'=>0])->get();
  137. $new_rule = [];
  138. foreach ($banner_rule->toArray() as $k=>$v){
  139. $new_rule[] = $v;
  140. }
  141. $group_array['content'][0]['rule'] = $new_rule;
  142. $group_array['content'][1]['area_type'] ="special";
  143. $subject_rule = $this->cmsContentTemplateSet->select('id','rule')->where(['tpl_id'=>$request['tpl_id'],'area_type'=>1])->get();
  144. $new_rule = [];
  145. foreach ($subject_rule->toArray() as $k=>$v){
  146. $new_rule[] = $v;
  147. }
  148. $group_array['content'][1]['rule'] = $new_rule;
  149. $group_array['content'][2]['area_type'] ="floor";
  150. $floor_rule = $this->cmsContentTemplateSet->select('id','rule')->where(['tpl_id'=>$request['tpl_id'],'area_type'=>2])->get();
  151. $new_rule = [];
  152. foreach ($floor_rule->toArray() as $k=>$v){
  153. $new_rule[] = $v;
  154. }
  155. foreach ($new_rule as $k=>$v){
  156. $rules = json_decode($v['rule'],true);
  157. $show_type = $this->cmsSubject->select('show_type')->where('id', $rules['link_url'])->first();
  158. $product = $this->cmsSubjectProduct->where('subject_id', $rules['link_url'])->orderBy('sort', 'asc')->get();
  159. $pro_array = $product->toArray();
  160. $res_id = implode(",", array_column($pro_array, 'id'));
  161. $new_rule[$k]['product_id'] = $res_id;
  162. $new_rule[$k]['subject_id'] = $rules['link_url'];
  163. $new_rule[$k]['show_type'] = $show_type->show_type ?? '';
  164. unset($v['url']);
  165. unset($v['show_num']);
  166. unset($rules['link_url']);
  167. unset($v['link_type']);
  168. }
  169. $group_array['content'][2]['rule'] = $new_rule;
  170. if ($request['type'] == 1){
  171. $group_array['content'][3]['area_type'] ="category";
  172. $category_rule = $this->cmsContentTemplateSet->select('rule')->where(['tpl_id'=>$request['tpl_id'],'area_type'=>3])->get();
  173. $new_rule = [];
  174. foreach ($category_rule->toArray() as $k=>$v){
  175. $new_rule[] = $v;
  176. }
  177. $group_array['content'][3]['rule'] = $new_rule;
  178. }
  179. $group_json = json_encode($group_array,JSON_UNESCAPED_UNICODE);
  180. return $group_json;
  181. }
  182. }