You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

107 lines
3.6 KiB

  1. <?php
  2. namespace App\Http\Controllers\Wap;
  3. use Illuminate\Support\Facades\DB;
  4. class GoodsController extends BaseController
  5. {
  6. public function __construct()
  7. {
  8. parent::__construct();
  9. }
  10. //商品列表页
  11. public function index($cat, $page = 0)
  12. {
  13. $pagenow = $page;
  14. if (empty($cat) || !preg_match('/[0-9]+/', $cat)) {
  15. return redirect()->route('page404');
  16. }
  17. $post = object_to_array(DB::table('product_type')->where('id', $cat)->first(), 1);
  18. if (empty($post)) {
  19. return redirect()->route('page404');
  20. }
  21. $data['post'] = $post;
  22. $subcat = "";
  23. $post2 = object_to_array(DB::table('product_type')->select('id')->where('pid', $cat)->get());
  24. if (!empty($post2)) {
  25. foreach ($post2 as $row) {
  26. $subcat = $subcat . "typeid=" . $row["id"] . " or ";
  27. }
  28. }
  29. $subcat = $subcat . "typeid=" . $cat;
  30. $data['sql'] = $subcat;
  31. $counts = DB::table("product")->whereRaw($subcat)->count();
  32. if ($counts > sysconfig('CMS_MAXARC')) {
  33. $counts = sysconfig('CMS_MAXARC');
  34. dd($counts);
  35. }
  36. $pagesize = sysconfig('CMS_PAGESIZE');
  37. $page = 0;
  38. if ($counts % $pagesize) {//取总数据量除以每页数的余数
  39. $pages = intval($counts / $pagesize) + 1; //如果有余数,则页数等于总数据量除以每页数的结果取整再加一,如果没有余数,则页数等于总数据量除以每页数的结果
  40. } else {
  41. $pages = $counts / $pagesize;
  42. }
  43. if (!empty($pagenow)) {
  44. if ($pagenow == 1 || $pagenow > $pages) {
  45. return redirect()->route('page404');
  46. }
  47. $page = $pagenow - 1;
  48. $nextpage = $pagenow + 1;
  49. $previouspage = $pagenow - 1;
  50. } else {
  51. $page = 0;
  52. $nextpage = 2;
  53. $previouspage = 0;
  54. }
  55. $data['page'] = $page;
  56. $data['pages'] = $pages;
  57. $data['counts'] = $counts;
  58. $start = $page * $pagesize;
  59. $data['posts'] = arclist(array("table" => "product", "sql" => $subcat, "limit" => "$start,$pagesize")); //获取列表
  60. $data['pagenav'] = get_listnav(array("counts" => $counts, "pagesize" => $pagesize, "pagenow" => $page + 1, "catid" => $cat, "urltype" => "product")); //获取分页列表
  61. if ($post['templist'] == 'category2') {
  62. if (!empty($pagenow)) {
  63. return redirect()->route('page404');
  64. }
  65. }
  66. return view('wap.goods.index', $data);
  67. }
  68. //商品详情页
  69. public function detail($id)
  70. {
  71. if (empty($id) || !preg_match('/[0-9]+/', $id)) {
  72. return redirect()->route('page404');
  73. }
  74. $post = object_to_array(DB::table('product')->where('id', $id)->first(), 1);
  75. if (empty($post)) {
  76. return redirect()->route('page404');
  77. }
  78. $post['name'] = DB::table('product_type')->where('id', $post['typeid'])->value('name');
  79. if (!$post) {
  80. return redirect()->route('page404');
  81. }
  82. $cat = $post['typeid'];
  83. $post['body'] = ReplaceKeyword($post['body']);
  84. if (!empty($post['writer'])) {
  85. $post['writertitle'] = $post['title'] . ' ' . $post['writer'];
  86. }
  87. $data['post'] = $post;
  88. $data['pre'] = get_article_prenext(array('aid' => $post["id"], 'typeid' => $post["typeid"], 'type' => "pre"));
  89. $post = object_to_array(DB::table('product_type')->where('id', $cat)->first(), 1);
  90. return view('wap.goods.detail', $data);
  91. }
  92. }