Index.php 2.6 KB

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