Product.php 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. <?php
  2. namespace app\api\controller;
  3. use think\Db;
  4. use think\db\Expression;
  5. use app\common\controller\Api;
  6. use app\common\model\ProductLists;
  7. use app\common\model\ProductsModel;
  8. use app\common\model\ProductPopular;
  9. use app\common\model\ProductTransfer;
  10. class Product extends Api
  11. {
  12. protected array $noNeedLogin = ['*'];
  13. protected string $lan = '';
  14. public function _initialize()
  15. {
  16. parent::_initialize();
  17. $this->lan = $this->request->getLan();
  18. }
  19. /**
  20. * 热销列表
  21. */
  22. public function getPopularList(ProductsModel $productsModel, ProductPopular $productPopular, ProductLists $productLists)
  23. {
  24. $item = $productsModel->where('status', 1)->column('id,'.$this->lan.'_title as title');
  25. $resp = array();
  26. foreach ($item as $kk =>$val) {
  27. $list= $productLists->where('type_id', $kk)->field('id,thum as img_url,'.$this->lan.'_name as name')->select();
  28. $i = 0;
  29. $proArr = array();
  30. foreach ($list as $key => &$item) {
  31. $pro =$productPopular
  32. ->field('id,product_id,price,cost_price,stock,num,start_time,end_time,status')
  33. ->where('product_id', $item['id'])
  34. ->where('status', '<', $productPopular::STOP)
  35. ->order('start_time')
  36. ->find();
  37. if(!empty($pro)){
  38. $proArr[$i] = $item;
  39. $proArr[$i]['pro'] = $pro;
  40. $i+=1;
  41. }
  42. }
  43. $resp[] = ['type_id'=>$kk,'title'=>$val, 'product'=>$proArr];
  44. }
  45. $this->success('', $resp);
  46. }
  47. /**
  48. * 转让列表
  49. * sort: 0 默认排序 1价格从高到低 2价格从低到高
  50. * type_id 分类
  51. * key_val 商品名称搜索
  52. */
  53. public function getTransferList(ProductTransfer $productTransfer)
  54. {
  55. $sort = $this->request->post('sort/d', '');
  56. $type_id = $this->request->post('type_id/s', '');
  57. $key_val = $this->request->post('key_val/s', '');
  58. $order = 'a.id DESC';
  59. $map = [];
  60. if($sort == 1) $order = 'a.price DESC';
  61. if($sort == 2) $order = 'a.price ASC';
  62. if($type_id > 0) $map['b.type_id'] = ['=', $type_id];
  63. if(!empty($key_val)) $map['b.'.$this->lan.'_name'] = ['like', '%'.$key_val.'%'];
  64. $list = $productTransfer->alias('a')
  65. ->join("product_list b", "a.product_id = b.id", "left")
  66. ->join("user u", "a.user_id = u.id", "left")
  67. ->join("products d", "b.type_id = d.id", "left")
  68. ->join("product_area dr", "dr.id = a.area_id", "left") //地区
  69. ->field('a.id,'.'b.'.$this->lan.'_name as name,b.thum as img_url,price,u.nickname,d.'.$this->lan.'_title as title,dr.address')
  70. ->where('a.status', $productTransfer::NORMAL)
  71. ->where($map)
  72. ->order($order)
  73. ->paginate($this->pageSize);
  74. $this->success('', $list);
  75. }
  76. }