Index.php 2.7 KB

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