123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190 |
- <?php
- namespace app\api\controller;
- use app\common\model\GoodsCate;
- use app\common\model\GoodsSeason;
- use app\common\model\GoodsServe;
- use app\common\model\StoreGoods;
- use app\common\model\User;
- use app\common\model\UserCollect;
- use app\common\model\UserSearch;
- use app\common\model\UserTrack;
- use app\common\model\WashCate;
- use app\common\service\Activity;
- use library\tools\Data;
- use think\Db;
- class Mall extends Base
- {
-
- public function initialize(){
- parent::initialize();
- parent::setUid();
- }
-
- public function getGoodsCate()
- {
- $list = GoodsCate::getCateTree();
- $this->success('ok',['list'=>$list]);
- }
-
- public function getWashCate()
- {
- $list = WashCate::where('is_deleted',0)->field('id,logo,title,ladder_set')->select()->toArray();
- array_walk($list,function (&$v,$k){
- $v['ladder_set'] = $v['ladder_set'] ? json_decode($v['ladder_set'],true):null;
- });
- $this->success('ok',['list'=>$list]);
- }
-
- public function getGoodsList(){
- $all_cate = GoodsCate::getCateTree();
- $all_cate = array_column($all_cate,null,'id');
- $input = input('get.');
- $sel_where = [];
- $sel_where[] = ['status','=',1];
- $sel_where[] = ['is_deleted','=',0];
- $sort_type = input('get.sort_type',1);
- if(isset_full($input,'first_classify'))$sel_where[] = ['first_classify','=',$input['first_classify']];
- switch ($sort_type) {
- case 1:
- $order = ['sort'=>'desc','id'=>'desc'];
- break;
- case 2:
- $order = ['id'=>'asc','sort'=>'desc'];
- break;
- case 3:
- $order = ['id'=>'desc','sort'=>'desc'];
- break;
- }
- $list = StoreGoods::with(['itemList'])
- ->field('id,name,cover,desc,low_price,first_classify')
- ->where($sel_where)->limit($this->off_set,$this->page_num)
- ->order($order)
- ->select()->toArray();
- foreach ($list as &$v){
- $v['first_classify_name'] = isset($all_cate[$v['first_classify']]['title']) ? $all_cate[$v['first_classify']]['title']:'';
- $v['low_original'] = empty($v['item_list']) ? 0 : min(array_column($v['item_list'],'original_price'));
- $v['low_price'] = empty($v['item_list']) ? 0 : min(array_column($v['item_list'],'sell_price'));
- $v['max_price'] = empty($v['item_list']) ? 0 : max(array_column($v['item_list'],'sell_price'));
- $v['total_num'] = empty($v['item_list']) ? 0 :array_sum(array_column($v['item_list'],'base_stock'));
- }
- $total_num = StoreGoods::where($sel_where)->count();
- $this->success('ok',['list'=>$list,'total_num'=>$total_num]);
- }
-
- public function getGoodsDetail()
- {
- $goods_id = input('goods_id');
- $all_cate = GoodsCate::getCateTree();
- $all_cate = array_column($all_cate,null,'id');
- $detail = StoreGoods::with(['itemList'])->field('specs,lists',true)->where('id',$goods_id)->find()->toArray();
- $detail['max_price'] = max(array_column($detail['item_list'],'original_price'));
- $detail['first_classify_name'] = isset($all_cate[$detail['first_classify']]['title']) ? $all_cate[$detail['first_classify']]['title']:'';
- $detail['low_original'] = empty($detail['item_list']) ? 0 : min(array_column($detail['item_list'],'original_price'));
- $detail['low_price'] = empty($detail['item_list']) ? 0 : min(array_column($detail['item_list'],'sell_price'));
- $detail['max_price'] = empty($detail['item_list']) ? 0 : max(array_column($detail['item_list'],'sell_price'));
- $detail['content_arr'] = $detail['content'] ? explode('|',$detail['content']) : null;
- $this->success('oK',['goods_info'=>$detail]);
- }
- }
|