Index.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. <?php
  2. namespace app\index\controller;
  3. use app\index\model\Article as ArticleModel;
  4. use app\index\model\Comment as CommentModel;
  5. use app\index\model\Goods as GoodsModel;
  6. /**
  7. * 默认控制器
  8. * Class Index
  9. * @package app\api\controller
  10. */
  11. class Index extends Controller
  12. {
  13. public function index()
  14. {
  15. //banner位
  16. //商品区。new,video,bestseller
  17. $model = new GoodsModel;
  18. $newArrival = $model->getList(['listType' => 'on_sale'], 4)->toArray()['data'];
  19. $bestseller = $model->getList(['sortType' => 'sales'], 4)->toArray()['data'];
  20. $superDeals = $model->getList(['categoryId' => '10002',], 3)->toArray()['data'];
  21. //dd($superDeals);
  22. //return $this->renderSuccess(compact('bestseller'));
  23. $newGoodsId = array_column($newArrival, 'goods_id');
  24. $bestGoodsId = array_column($bestseller, 'goods_id');
  25. $superDealsGoodsId = array_column($superDeals, 'goods_id');
  26. //获取评价数量
  27. $goodsIds = array_unique(array_merge($newGoodsId, $bestGoodsId, $superDealsGoodsId));
  28. $commentModel = new CommentModel();
  29. $rows = $commentModel->rowsTotalBatch($goodsIds)->toArray();
  30. $rowsByGoodsId = array_column($rows, 'cnt', 'goods_id');
  31. //获取评论分数
  32. $commentScores = $commentModel->getTotalAll($goodsIds)->toArray();
  33. $scoresByGoodsId = array_column($commentScores, 'score_total', 'goods_id');
  34. //dd($rowsByGoodsId);
  35. //可考虑缓存
  36. foreach ($newArrival as &$item) {
  37. $item['comment_cnt'] = $rowsByGoodsId[$item['goods_id']] ?? 0;
  38. $temp = bcmul($item['comment_cnt'], 10, 0);
  39. $item['avg_score'] = bcdiv($scoresByGoodsId[$item['goods_id']] ?? '0', $temp, 0);
  40. }
  41. foreach ($bestseller as &$item) {
  42. $item['comment_cnt'] = $rowsByGoodsId[$item['goods_id']] ?? 0;
  43. $temp = bcmul($item['comment_cnt'], 10, 0);
  44. $item['avg_score'] = bcdiv($scoresByGoodsId[$item['goods_id']], $temp, 0);
  45. }
  46. foreach ($superDeals as &$item) {
  47. $item['comment_cnt'] = $rowsByGoodsId[$item['goods_id']] ?? 0;
  48. $temp = bcmul($item['comment_cnt'], 10, 0);
  49. $item['avg_score'] = bcdiv($scoresByGoodsId[$item['goods_id']], $temp, 0);
  50. }
  51. $model = new ArticleModel;
  52. $article = $model->getList(0, 5)->toArray()['data'];
  53. foreach ($article as &$datum) {
  54. $datum['year'] = substr($datum['create_time'], 0, 4);
  55. $datum['month_day'] = substr($datum['create_time'], 5, 5);
  56. $datum['date'] = substr($datum['create_time'], 0, 10);
  57. }
  58. //dd($article);
  59. return view('/index/index', [
  60. 'newGoods' => $newArrival,
  61. 'bestseller' => $bestseller,
  62. 'superDealsOne' => $superDeals,
  63. 'superDealsTwo' => $superDeals,
  64. 'article' => $article,
  65. ]);
  66. }
  67. public function productDetails()
  68. {
  69. $goodsId = $this->request->param('goodsId', 0);
  70. if (empty($goodsId)) {
  71. return \redirect('index');
  72. }
  73. $goodsModel = new GoodsModel();
  74. $goods = $goodsModel->getDetails($goodsId)->toArray();
  75. $goods['content'] = html_entity_decode($goods['content']);
  76. $model = new CommentModel;
  77. $total = $model->rowsTotal($goodsId);
  78. return view('productDetails', ['goods' => $goods, 'comment_total' => $total]);
  79. }
  80. }