Groupon.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <?php
  2. namespace addons\shopro\controller\activity;
  3. use addons\shopro\controller\Common;
  4. use app\admin\model\shopro\activity\Groupon as GrouponModel;
  5. use app\admin\model\shopro\activity\GrouponLog as GrouponLogModel;
  6. use addons\shopro\service\goods\GoodsService;
  7. use addons\shopro\facade\Activity as ActivityFacade;
  8. class Groupon extends Common
  9. {
  10. protected $noNeedLogin = ['index', 'detail'];
  11. protected $noNeedRight = ['*'];
  12. // 商品详情,参团列表
  13. public function index()
  14. {
  15. $params = $this->request->param();
  16. $goods_id = $params['goods_id'] ?? 0;
  17. $activity_id = $params['activity_id'] ?? 0;
  18. $groupons = GrouponModel::with('leader')->ing()
  19. ->where('goods_id', $goods_id)
  20. ->where('activity_id', $activity_id)
  21. ->order('id', 'asc')
  22. // ->paginate($this->request->param('list_rows', 10));
  23. ->autopage()->select();
  24. $this->success('获取成功', $groupons);
  25. }
  26. //某个拼团详情
  27. public function detailnew(){
  28. $id = $this->request->param('id');
  29. $groupon = GrouponModel::with(['groupon_logs'])->where('id', $id)->find();
  30. if (!$groupon) {
  31. $this->error(__('No Results were found'));
  32. }
  33. $service = new GoodsService();
  34. // 查询所有状态的商品,并且包含被删除的商品
  35. $goods = $service->withTrashed()->where('id', $groupon->goods_id)->find();
  36. if (!$goods) {
  37. $this->error('活动商品不存在');
  38. }
  39. $groupon['goods'] = $goods;
  40. $this->success('获取成功', $groupon);
  41. }
  42. // 团详情
  43. public function detail()
  44. {
  45. $id = $this->request->param('id');
  46. $groupon = GrouponModel::with(['my', 'groupon_logs', 'activity' => function ($query) {
  47. $query->removeOption('soft_delete')->with(['activity_sku_prices']); // 关联团所属活动,并关联活动规格
  48. }])->where('id', $id)->find();
  49. if (!$groupon) {
  50. $this->error(__('No Results were found'));
  51. }
  52. session('goods-activity_id:' . $groupon->goods_id, $groupon->activity_id);
  53. $service = new GoodsService(function ($goods, $service) use ($groupon) {
  54. $goods->skus = $goods->skus;
  55. $goods->activity = $goods->activity;
  56. return $goods;
  57. });
  58. // 查询所有状态的商品,并且包含被删除的商品
  59. $goods = $service->activity($groupon->activity_id)->withTrashed()->where('id', $groupon->goods_id)->find();
  60. if (!$goods) {
  61. $this->error('活动商品不存在');
  62. }
  63. // 商品可能关联不出来活动,因为活动可能已经被删除,redis 也会被删除
  64. if (!$currentActivity = $goods->activity) {
  65. // 活动已经结束被删除
  66. if ($currentActivity = $groupon->activity) { // 尝试获取包含回收站在内的活动信息
  67. // 获取活动格式化之后的规格
  68. $skuPrices = ActivityFacade::recoverSkuPrices($goods, $currentActivity);
  69. $goods['new_sku_prices'] = $skuPrices;
  70. }
  71. }
  72. $goods = $goods->toArray();
  73. $goods['sku_prices'] = $goods['new_sku_prices'];
  74. unset($goods['new_sku_prices']);
  75. $groupon['goods'] = $goods;
  76. $groupon['activity_status'] = $currentActivity['status'];
  77. $this->success('获取成功', $groupon);
  78. }
  79. // 我的拼团
  80. public function myGroupons()
  81. {
  82. $user = auth_user();
  83. $params = $this->request->param();
  84. $type = $params['type'] ?? 'all';
  85. $grouponIds = GrouponLogModel::where('user_id', $user->id)->order('id', 'desc')->column('groupon_id');
  86. $groupons = GrouponModel::with(['my' => function ($query) {
  87. $query->with(['order', 'order_item']);
  88. }, 'groupon_logs', 'activity' => function ($query) {
  89. $query->removeOption('soft_delete')->with(['activity_sku_prices']); // 关联团所属活动,并关联活动规格
  90. }, 'goods' => function ($query) {
  91. $query->removeOption('soft_delete');
  92. }])->whereIn('id', $grouponIds);
  93. if ($type != 'all') {
  94. $type = $type == 'finish' ? ['finish', 'finish-fictitious'] : [$type];
  95. $groupons = $groupons->whereIn('status', $type);
  96. }
  97. if ($grouponIds) {
  98. $groupons = $groupons->orderRaw('field(id, ' . join(',', $grouponIds) . ')');
  99. }
  100. $groupons = $groupons->paginate(request()->param('list_rows', 10))->toArray();
  101. foreach ($groupons['data'] as &$groupon) {
  102. if ($groupon['goods'] && isset($groupon['my']['order_item'])) {
  103. $groupon['goods']['price'] = [$groupon['my']['order_item']['goods_price']];
  104. }
  105. if ($groupon['activity']) {
  106. $activity = $groupon['activity'];
  107. if ($activity['rules'] && isset($activity['rules']['sales_show_type']) && $activity['rules']['sales_show_type'] == 'real') {
  108. $sales = [];
  109. foreach ($activity['activity_sku_prices'] as $activitySkuPrice) {
  110. if ($activitySkuPrice['goods_id'] == $groupon['goods_id']) {
  111. $sales[] = $activitySkuPrice['sales'];
  112. }
  113. }
  114. if ($groupon['goods']) {
  115. $groupon['goods']['sales'] = array_sum($sales); // 这里计算的销量和 getSalesAttr 不一样,这里的没有排除下架的规格
  116. }
  117. }
  118. }
  119. }
  120. $this->success('获取成功', $groupons);
  121. }
  122. }