海南旅游SAAS
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

189 lines
5.8 KiB

  1. <?php
  2. namespace App\Http\Controllers\Api;
  3. use App\Common\ProductStatus;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\Advertising;
  6. use App\Models\AgentProduct;
  7. use App\Models\Product;
  8. use App\Models\UserFav;
  9. use Illuminate\Support\Facades\Storage;
  10. /**
  11. * 代理商产品
  12. * Class AgentProductController
  13. * @package App\Http\Controllers\Api
  14. */
  15. class AgentProductController extends Controller
  16. {
  17. // 代理商产品列表
  18. public function index()
  19. {
  20. $category_id = request()->input('category_id');
  21. $where = [];
  22. if ($category_id) {
  23. $where['category_id'] = $category_id;
  24. }
  25. $list = AgentProduct::list($this->agent_id)->where($where)->orderBy('id', 'DESC')->simplePaginate();
  26. $list = $this->paginatePicAddHost($list);
  27. $list = $this->insertAd($list);
  28. return $this->success($list);
  29. }
  30. //首页搜索框
  31. public function search()
  32. {
  33. $keywords = request()->input('keywords');
  34. $type = request()->input('type', 0);
  35. $by = request()->input('by', 0);
  36. if (!$keywords) {
  37. return $this->error('请输入关键词');
  38. }
  39. $fields = ['id', 'sale', 'updated_at', 'price'];
  40. $field = $fields[$type] ?? $fields[0];
  41. $by = $by == 0 ? 'desc' : 'asc';
  42. $list = AgentProduct::list($this->agent_id)->where('title', 'like', "%$keywords%")->orderBy($field, $by)->simplePaginate();
  43. $list = $this->paginatePicAddHost($list);
  44. return $this->success($list);
  45. }
  46. // 产品详情
  47. public function show()
  48. {
  49. $id = (int)request()->input('id');
  50. // TODO 优惠券查询待优化
  51. $agent_product = AgentProduct::query()
  52. ->with(['coupon:tag,agent_product_id', 'fav:agent_product_id'])
  53. ->whereDoesntHave('agentProductItem', function ($query) {
  54. return $query->whereHas('product', function ($query) {
  55. return $query->where('stock', '<=', 0)->orWhere('status', '<>', ProductStatus::ON_SALE);
  56. });
  57. })
  58. ->where('stock', '>', 0)
  59. ->firstWhere(['id' => $id, 'agent_id' => $this->agent_id, 'status' => ProductStatus::ON_SALE]);
  60. if (!$agent_product) {
  61. return $this->error('产品已下架或库存不足');
  62. }
  63. $prefix = Storage::disk('public')->url('');
  64. $agent_product->pictures = array_map(fn($item) => ($prefix . $item), $agent_product->pictures);
  65. $agent_product->is_collect = !is_null($agent_product->fav); //判断是否收藏
  66. unset($agent_product->fav);
  67. //计算折扣
  68. if ($agent_product->price < $agent_product->original_price) {
  69. $agent_product->cost = round($agent_product->price / $agent_product->original_price * 10, 1);
  70. } else {
  71. $agent_product->cost = '';
  72. }
  73. //如果是单品销售,显示附加信息字段,组合产品和组团产品不显示
  74. if ($agent_product->type == 0) {
  75. $agent_product->product = Product::query()->where('id', $agent_product->product_id)->first(['type', 'extends']);
  76. } else {
  77. $agent_product->product = null;
  78. }
  79. unset($agent_product->agent_id, $agent_product->status, $agent_product->deleted_at);
  80. return $this->success($agent_product);
  81. }
  82. // 猜你喜欢
  83. public function guessLike()
  84. {
  85. $list = AgentProduct::list($this->agent_id)->orderBy('id', 'DESC')->simplePaginate();
  86. $list = $this->paginatePicAddHost($list);
  87. $list = $list->toArray();
  88. if (!empty($list['data']) && is_array($list['data'])) {
  89. shuffle($list['data']); //随机乱序
  90. }
  91. $list = $this->insertAd($list);
  92. return $this->success($list);
  93. }
  94. //【我的】页面下方推荐
  95. public function recommendList()
  96. {
  97. $list = AgentProduct::list($this->agent_id)->where(['is_rec' => 1])
  98. ->orderBy('id', 'DESC')->simplePaginate();
  99. $list = $this->paginatePicAddHost($list);
  100. $list = $this->insertAd($list);
  101. return $this->success($list);
  102. }
  103. //人气爆款列表,销量排序
  104. public function hotList()
  105. {
  106. $list = AgentProduct::list($this->agent_id)
  107. ->orderBy('sale', 'DESC')->orderBy('id', 'DESC')->simplePaginate();
  108. $list = $this->paginatePicAddHost($list);
  109. $list = $this->insertAd($list);
  110. return $this->success($list);
  111. }
  112. //分页列表产品图片加域名
  113. private function paginatePicAddHost($list)
  114. {
  115. //如果是新入驻代理商没有数据,且没有删除过的数据,则显示最早的几条
  116. if ($list->isEmpty()) {
  117. if (AgentProduct::list($this->agent_id)->withTrashed()->count() === 0 && request('page', 1) <= 2) { //只获取2页数据
  118. $list = AgentProduct::list($this->agent_id)->orWhereRaw(1)->orderBy('id')->simplePaginate();
  119. } else {
  120. return $list; //因为只获取2页数据,不return可能会导入下面的代码出错
  121. }
  122. }
  123. $prefix = Storage::disk('public')->url('');
  124. foreach ($list->items() as $k=>&$v) {
  125. $v->pictures = array_map(function($item) use ($prefix) {
  126. return strpos($item, $prefix) === false ? $prefix . $item : $item;
  127. }, $v->pictures);
  128. }
  129. return $list;
  130. }
  131. //插入瀑布流广告
  132. private function insertAd($list)
  133. {
  134. //插入瀑布流广告,分别在第8个和第16个插入,同时需要考虑到分页。当所有瀑布流广告插入完之后,再次循环插入
  135. if (is_object($list) && method_exists($list, 'toArray')) {
  136. $list = $list->toArray();
  137. }
  138. $ad_total = Advertising::where(['agent_id' => $this->agent_id, 'status' => 1, 'display' => 2])->count();
  139. if ($list['data'] && $ad_total > 0) {
  140. $page = (int)request()->input('page');
  141. $start = ($page ? $page - 1 : 0) * 2 % $ad_total;
  142. $ad = Advertising::where(['agent_id' => $this->agent_id, 'status' => 1, 'display' => 2])
  143. ->orderBy('sort')->orderBy('id', 'DESC')
  144. ->offset($start)->limit(2)->get(['title', 'picture', 'type', 'url'])->toArray();
  145. $prefix = Storage::disk('public')->url('');
  146. foreach ($ad as $k => &$v) {
  147. $v['is_ad'] = true;
  148. $v['picture'] = $prefix . $v['picture'];
  149. //每隔8个插入广告
  150. $temp = 8 * ($k+1);
  151. if (!empty($list['data'][$temp - 1]) && !empty($ad[$k])) {
  152. array_splice($list['data'], $temp + $k, 0, [$ad[$k]]);
  153. }
  154. }
  155. }
  156. return $list;
  157. }
  158. }