StoreExchangeController.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. <?php
  2. namespace app\api\controller\activity;
  3. use app\admin\model\store\StoreDescription;
  4. use app\admin\model\store\StoreProductAttrValue;
  5. use app\models\store\StoreExchange;
  6. use app\models\store\StoreIntegral;
  7. use app\models\store\StoreProductAttr;
  8. use app\models\store\StoreProductRelation;
  9. use app\models\store\StoreProductReply;
  10. //use app\models\store\StoreSeckill;
  11. use app\models\store\StoreVisit;
  12. use app\Request;
  13. use crmeb\services\GroupDataService;
  14. use crmeb\services\QrcodeService;
  15. use crmeb\services\UtilService;
  16. /**
  17. * 秒杀产品类
  18. * Class StoreSeckillController
  19. * @package app\api\controller\activity
  20. */
  21. class StoreExchangeController
  22. {
  23. /**
  24. * 积分产品列表
  25. * @param Request $request
  26. * @param $time
  27. * @return mixed
  28. * @throws \think\db\exception\DataNotFoundException
  29. * @throws \think\db\exception\ModelNotFoundException
  30. * @throws \think\exception\DbException
  31. */
  32. public function lst(Request $request)
  33. {
  34. list($page, $limit) = UtilService::getMore([
  35. ['page', 0],
  36. ['limit', 0],
  37. ], $request, true);
  38. // var_dump(111);
  39. $seckillInfo = StoreExchange::seckillList($page, $limit);
  40. if (count($seckillInfo)) {
  41. foreach ($seckillInfo as $key => &$item) {
  42. if ($item['quota'] > 0) {
  43. $quota = StoreProductAttrValue::where('product_id', $item['id'])->where('type', 5)->value('SUM(quota)');
  44. $percent = (int)bcmul(bcdiv(bcsub($item['quota'], $quota), $item['quota'], 2), 100, 0);
  45. $item['percent'] = $percent;
  46. $item['stock'] = $quota;
  47. } else {
  48. $item['percent'] = 100;
  49. $item['stock'] = 0;
  50. }
  51. }
  52. }
  53. return app('json')->successful($seckillInfo);
  54. }
  55. /**
  56. * 秒杀产品详情
  57. * @param Request $request
  58. * @param $id
  59. * @return mixed
  60. */
  61. public function detail(Request $request, $id, $time = 0)
  62. {
  63. if (!$id || !($storeInfo = StoreExchange::getValidProduct($id))) return app('json')->fail('商品不存在或已下架!');
  64. $storeInfo = $storeInfo->hidden(['cost', 'add_time', 'is_del'])->toArray();
  65. $siteUrl = sys_config('site_url');
  66. $storeInfo['image'] = set_file_url($storeInfo['image'], $siteUrl);
  67. $storeInfo['image_base'] = set_file_url($storeInfo['image'], $siteUrl);
  68. $storeInfo['code_base'] = QrcodeService::getWechatQrcodePath($id . '_seckill_detail_wap.jpg', '/activity/seckill_detail/' . $id . '/' . $time);
  69. $uid = $request->uid();
  70. $storeInfo['userLike'] = StoreProductRelation::isProductRelation($id, $uid, 'like', 'product_seckill');
  71. $storeInfo['like_num'] = StoreProductRelation::productRelationNum($id, 'like', 'product_seckill');
  72. $storeInfo['userCollect'] = StoreProductRelation::isProductRelation($storeInfo['product_id'], $uid, 'collect');
  73. $storeInfo['uid'] = $uid;
  74. $storeInfo['description'] = htmlspecialchars_decode(StoreDescription::getDescription($id, 5));
  75. $data['storeInfo'] = $storeInfo;
  76. StoreVisit::setView($uid, $id, $storeInfo['product_id'], 'viwe');
  77. $data['reply'] = StoreProductReply::getRecProductReply($storeInfo['product_id']);
  78. $data['replyCount'] = StoreProductReply::productValidWhere()->where('product_id', $storeInfo['product_id'])->count();
  79. if ($data['replyCount']) {
  80. $goodReply = StoreProductReply::productValidWhere()->where('product_id', $storeInfo['product_id'])->where('product_score', 5)->count();
  81. $data['replyChance'] = $goodReply;
  82. if ($goodReply) {
  83. $data['replyChance'] = bcdiv($goodReply, $data['replyCount'], 2);
  84. $data['replyChance'] = bcmul($data['replyChance'], 100, 3);
  85. }
  86. } else $data['replyChance'] = 0;
  87. list($productAttr, $productValue) = StoreProductAttr::getProductAttrDetail($id, $uid, 0, 5);
  88. foreach ($productValue as $k => $v) {
  89. $productValue[$k]['product_stock'] = StoreProductAttrValue::where('product_id', $storeInfo['product_id'])->where('suk', $v['suk'])->where('type', 0)->value('stock');
  90. }
  91. $data['productAttr'] = $productAttr;
  92. $data['productValue'] = $productValue;
  93. return app('json')->successful($data);
  94. }
  95. }