StoreIntegralController.php 4.3 KB

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