fetch(); } /** * 商品详情页 */ public function goodsInfo() { $goodsLogic = new GoodsLogic(); $goods_id = I("get.id/d"); $Goods = new \app\common\model\Goods(); $goods = $Goods->where('goods_id',$goods_id)->find(); if (empty($goods) || ($goods['is_on_sale'] == 0)) { $this->error('该商品已经下架', U('Index/index')); } if(($goods['is_virtual'] == 1 && $goods['virtual_indate'] <= time())){ $goods->save(['is_on_sale' => 0]); $this->error('此商品不存在或者已下架', U('Index/index')); } if (cookie('user_id')) { $goodsLogic->add_visit_log(cookie('user_id'), $goods); } $goods->save(['click_count'=>$goods['click_count'] + 1]);//点击数 $this->assign('goods', $goods); return $this->fetch(); } public function activity() { $goods_id = input('goods_id/d');//商品id $item_id = input('item_id/d');//规格id $goods_num = input('goods_num/d');//欲购买的商品数量 $Goods = new \app\common\model\Goods(); $goods = $Goods::get($goods_id); $goodsPromFactory = new GoodsPromFactory(); $goods['activity_is_on'] = 0; if ($goodsPromFactory->checkPromType($goods['prom_type'])) { //这里会自动更新商品活动状态,所以商品需要重新查询 if ($item_id) { $specGoodsPrice = SpecGoodsPrice::get($item_id); $goodsPromLogic = $goodsPromFactory->makeModule($goods, $specGoodsPrice); } else { $goodsPromLogic = $goodsPromFactory->makeModule($goods, null); } if ($goodsPromLogic->checkActivityIsAble()) { $goods = $goodsPromLogic->getActivityGoodsInfo(); $goods['activity_is_on'] = 1; $this->ajaxReturn(['status' => 1, 'msg' => '该商品参与活动', 'result' => ['goods' => $goods]]); } else { if (!empty($goods['price_ladder'])) { $goodsLogic = new GoodsLogic(); $goods->shop_price = $goodsLogic->getGoodsPriceByLadder($goods_num, $goods['shop_price'], $goods['price_ladder']); } $this->ajaxReturn(['status' => 1, 'msg' => '该商品没有参与活动', 'result' => ['goods' => $goods]]); } } if (!empty($goods['price_ladder'])) { $goodsLogic = new GoodsLogic(); $goods->shop_price = $goodsLogic->getGoodsPriceByLadder($goods_num, $goods['shop_price'], $goods['price_ladder']); } $this->ajaxReturn(['status' => 1, 'msg' => '该商品没有参与活动', 'result' => ['goods' => $goods]]); } /** * 获取可发货地址 */ public function getRegion() { $goodsLogic = new GoodsLogic(); $region_list = $goodsLogic->getRegionList();//获取配送地址列表 $region_list['status'] = 1; $this->ajaxReturn($region_list); } /** * 商品列表页 */ public function goodsList() { $key = md5($_SERVER['REQUEST_URI'] . I('start_price') . '_' . I('end_price')); $html = S($key); if (!empty($html)) { return $html; } $filter_param = array(); // 帅选数组 $id = I('get.id/d', 1); // 当前分类id $brand_id = I('get.brand_id', 0); $spec = I('get.spec', 0); // 规格 $attr = I('get.attr', ''); // 属性 $sort = I('get.sort', 'sort'); // 排序 $sort_asc = I('get.sort_asc', 'desc'); // 排序 $price = I('get.price', ''); // 价钱 $start_price = trim(I('post.start_price', '0')); // 输入框价钱 $end_price = trim(I('post.end_price', '0')); // 输入框价钱 if ($start_price && $end_price) $price = $start_price . '-' . $end_price; // 如果输入框有价钱 则使用输入框的价钱 $filter_param['id'] = $id; //加入帅选条件中 $brand_id && ($filter_param['brand_id'] = $brand_id); //加入帅选条件中 $spec && ($filter_param['spec'] = $spec); //加入帅选条件中 $attr && ($filter_param['attr'] = $attr); //加入帅选条件中 $price && ($filter_param['price'] = $price); //加入帅选条件中 $goodsLogic = new GoodsLogic(); // 前台商品操作逻辑类 // 分类菜单显示 $goodsCate = M('GoodsCategory')->where("id", $id)->find();// 当前分类 //($goodsCate['level'] == 1) && header('Location:'.U('Home/Channel/index',array('cat_id'=>$id))); //一级分类跳转至大分类馆 $cateArr = $goodsLogic->get_goods_cate($goodsCate); // 帅选 品牌 规格 属性 价格 $cat_id_arr = getCatGrandson($id); $goods_where = ['is_on_sale' => 1, 'exchange_integral' => 0, 'cat_id' => ['in',$cat_id_arr],'is_virtual'=>['eq', 0]]; $filter_goods_id = Db::name('goods')->where($goods_where)->cache(true)->getField("goods_id", true); // 过滤帅选的结果集里面找商品 if ($brand_id || $price)// 品牌或者价格 { $goods_id_1 = $goodsLogic->getGoodsIdByBrandPrice($brand_id, $price); // 根据 品牌 或者 价格范围 查找所有商品id $filter_goods_id = array_intersect($filter_goods_id, $goods_id_1); // 获取多个帅选条件的结果 的交集 } if ($spec)// 规格 { $goods_id_2 = $goodsLogic->getGoodsIdBySpec($spec); // 根据 规格 查找当所有商品id $filter_goods_id = array_intersect($filter_goods_id, $goods_id_2); // 获取多个帅选条件的结果 的交集 } if ($attr)// 属性 { $goods_id_3 = $goodsLogic->getGoodsIdByAttr($attr); // 根据 规格 查找当所有商品id $filter_goods_id = array_intersect($filter_goods_id, $goods_id_3); // 获取多个帅选条件的结果 的交集 } $filter_menu = $goodsLogic->get_filter_menu($filter_param, 'goodsList'); // 获取显示的帅选菜单 $filter_price = $goodsLogic->get_filter_price($filter_goods_id, $filter_param, 'goodsList'); // 帅选的价格期间 $filter_brand = $goodsLogic->get_filter_brand($filter_goods_id, $filter_param, 'goodsList'); // 获取指定分类下的帅选品牌 $filter_spec = $goodsLogic->get_filter_spec($filter_goods_id, $filter_param, 'goodsList', 1); // 获取指定分类下的帅选规格 $filter_attr = $goodsLogic->get_filter_attr($filter_goods_id, $filter_param, 'goodsList', 1); // 获取指定分类下的帅选属性 $count = count($filter_goods_id); $page = new Page($count, 20); if ($count > 0) { /*有的数据库分页第二页数据重复 $p = isset($_GET['p']) ? $_GET['p'] : 1; if ($sort_asc == 'asc') { asort($filter_goods_id); } else { arsort($filter_goods_id); } $page_num = ceil($count / 20); //总页数 if($page_num > 1){ for ($i=0;$i<$count;$i++) { $filter_goods_id = array_slice($filter_goods_id, ($p-1)*20, 20); } } $goods_list = M('goods')->where("goods_id", "in", implode(',', $filter_goods_id))->limit(20)->select();*/ $sort_asc = $sort_asc == 'asc' ? 'desc' : 'asc'; // 防注入 $sort_arr = ['sales_sum','shop_price','is_new','comment_count','sort']; if(!in_array($sort,$sort_arr)) $sort='sort'; // 防注入 $goods_list = M('goods')->where("goods_id", "in", implode(',', $filter_goods_id))->order([$sort => $sort_asc])->limit($page->firstRow . ',' . $page->listRows)->select(); $filter_goods_id2 = get_arr_column($goods_list, 'goods_id'); if ($filter_goods_id2) $goods_images = M('goods_images')->where("goods_id", "in", implode(',', $filter_goods_id2))->cache(true)->select(); } // print_r($filter_menu); $goods_category = M('goods_category')->where('is_show=1')->cache(true)->getField('id,name,parent_id,level'); // 键值分类数组 $this->assign('goods_list', $goods_list); $this->assign('goods_category', $goods_category); $this->assign('goods_images', $goods_images); // 相册图片 $this->assign('filter_menu', $filter_menu); // 帅选菜单 $this->assign('filter_spec', $filter_spec); // 帅选规格 $this->assign('filter_attr', $filter_attr); // 帅选属性 $this->assign('filter_brand', $filter_brand); // 列表页帅选属性 - 商品品牌 $this->assign('filter_price', $filter_price);// 帅选的价格期间 $this->assign('goodsCate', $goodsCate); $this->assign('cateArr', $cateArr); $this->assign('filter_param', $filter_param); // 帅选条件 $this->assign('cat_id', $id); $this->assign('page', $page);// 赋值分页输出 $html = $this->fetch(); S($key, $html); return $html; } /** * 查询配送地址,并执行回调函数 */ public function region() { $fid = I('fid/d'); $callback = I('callback'); $parent_region = M('region')->field('id,name')->where(array('parent_id' => $fid))->cache(true)->select(); echo $callback . '(' . json_encode($parent_region) . ')'; exit; } /** * 商品物流配送和运费 */ public function dispatching() { $goods_id = I('goods_id/d');//143 $region_id = I('region_id/d');//28242 $Goods = new \app\common\model\Goods(); $goods = $Goods->cache(true)->where('goods_id', $goods_id)->find(); $freightLogic = new FreightLogic(); $freightLogic->setGoodsModel($goods); $freightLogic->setRegionId($region_id); $freightLogic->setGoodsNum(1); $isShipping = $freightLogic->checkShipping(); if ($isShipping) { $freightLogic->doCalculation(); $freight = $freightLogic->getFreight(); $dispatching_data = ['status' => 1, 'msg' => '可配送', 'result' => ['freight' => $freight]]; } else { $dispatching_data = ['status' => 0, 'msg' => '该地区不支持配送', 'result' => '']; } $this->ajaxReturn($dispatching_data); } /** * 商品搜索列表页 */ //==========================================================================这个是首页热门搜索用的 //==========================================================================这个是首页热门搜索用的 //==========================================================================这个是首页热门搜索用的 public function search() { //C('URL_MODEL',0); $filter_param = array(); // 帅选数组 $id = I('get.id/d', 0); // 当前分类id $brand_id = I('brand_id', 0); $sort = I('sort', 'sort'); // 排序 $sort_asc = I('sort_asc', 'desc'); // 排序 $price = I('price', ''); // 价钱 $start_price = trim(I('start_price', '0')); // 输入框价钱 $end_price = trim(I('end_price', '0')); // 输入框价钱 if ($start_price && $end_price) $price = $start_price . '-' . $end_price; // 如果输入框有价钱 则使用输入框的价钱 $q = urldecode(trim(I('q', ''))); // 关键字搜索 // empty($q) && $this->error('请输入搜索词'); $id && ($filter_param['id'] = $id); //加入帅选条件中 $brand_id && ($filter_param['brand_id'] = $brand_id); //加入帅选条件中 $price && ($filter_param['price'] = $price); //加入帅选条件中 $q && ($_GET['q'] = $filter_param['q'] = $q); //加入帅选条件中 $goodsLogic = new GoodsLogic(); // 前台商品操作逻辑类 $SearchWordLogic = new SearchWordLogic(); $where = $SearchWordLogic->getSearchWordWhere($q); $where['is_on_sale'] = 1; Db::name('search_word')->where('keywords', $q)->setInc('search_num'); $goodsHaveSearchWord = Db::name('goods')->where($where)->count(); if ($goodsHaveSearchWord) { $SearchWordIsHave = Db::name('search_word')->where('keywords', $q)->find(); if ($SearchWordIsHave) { Db::name('search_word')->where('id', $SearchWordIsHave['id'])->update(['goods_num' => $goodsHaveSearchWord]); } else { $SearchWordData = [ 'keywords' => $q, 'pinyin_full' => $SearchWordLogic->getPinyinFull($q), 'pinyin_simple' => $SearchWordLogic->getPinyinSimple($q), 'search_num' => 1, 'goods_num' => $goodsHaveSearchWord ]; Db::name('search_word')->insert($SearchWordData); } } if ($id) { $cat_id_arr = getCatGrandson($id); $where['cat_id'] = array('in', implode(',', $cat_id_arr)); } $search_goods = M('goods')->where($where)->getField('goods_id,cat_id'); $filter_goods_id = array_keys($search_goods); $filter_cat_id = array_unique($search_goods); // 分类需要去重 if ($filter_cat_id) { $cateArr = M('goods_category')->where("id", "in", implode(',', $filter_cat_id))->select(); $tmp = $filter_param; foreach ($cateArr as $k => $v) { $tmp['id'] = $v['id']; $cateArr[$k]['href'] = U("/Home/Goods/search", $tmp); } } // 过滤帅选的结果集里面找商品 if ($brand_id || $price) { // 品牌或者价格 $goods_id_1 = $goodsLogic->getGoodsIdByBrandPrice($brand_id, $price); // 根据 品牌 或者 价格范围 查找所有商品id $filter_goods_id = array_intersect($filter_goods_id, $goods_id_1); // 获取多个帅选条件的结果 的交集 } $filter_menu = $goodsLogic->get_filter_menu($filter_param, 'search'); // 获取显示的帅选菜单 $filter_price = $goodsLogic->get_filter_price($filter_goods_id, $filter_param, 'search'); // 帅选的价格期间 $filter_brand = $goodsLogic->get_filter_brand($filter_goods_id, $filter_param, 'search'); // 获取指定分类下的帅选品牌 $count = count($filter_goods_id); $page = new Page($count, 20); if ($count > 0) { $sort_asc = $sort_asc == 'asc' ? 'desc' : 'asc'; // 防注入 $sort_arr = ['sales_sum','shop_price','is_new','comment_count','sort']; if(!in_array($sort,$sort_arr)) $sort='sort'; // 防注入 $goods_list = M('goods')->where(['is_on_sale' => 1, 'goods_id' => ['in', implode(',', $filter_goods_id)]])->order([$sort => $sort_asc])->limit($page->firstRow . ',' . $page->listRows)->select(); $filter_goods_id2 = get_arr_column($goods_list, 'goods_id'); if ($filter_goods_id2) $goods_images = M('goods_images')->where("goods_id", "in", implode(',', $filter_goods_id2))->select(); } $this->assign('goods_list', $goods_list); $this->assign('goods_images', $goods_images); // 相册图片 $this->assign('filter_menu', $filter_menu); // 帅选菜单 $this->assign('filter_brand', $filter_brand); // 列表页帅选属性 - 商品品牌 $this->assign('filter_price', $filter_price);// 帅选的价格期间 $this->assign('cateArr', $cateArr); $this->assign('filter_param', $filter_param); // 帅选条件 $this->assign('cat_id', $id); $this->assign('page', $page);// 赋值分页输出 $this->assign('q', I('q')); C('TOKEN_ON', false); return $this->fetch(); } /** * 商品咨询ajax分页 */ public function ajax_consult() { $goods_id = I("goods_id/d", '0'); $consult_type = I('consult_type', '0'); // 0全部咨询 1 商品咨询 2 支付咨询 3 配送 4 售后 $where = ['parent_id' => 0, 'goods_id' => $goods_id, 'is_show' => 1]; $consult_type > 0 ? $where['consult_type'] = $consult_type : false; $goodsConsultModel = new \app\common\model\GoodsConsult(); $count = $goodsConsultModel->where($where)->count(); $page = new AjaxPage($count, 5); $consultList = $goodsConsultModel->where($where)->order("id desc")->limit($page->firstRow, $page->listRows)->order('add_time desc')->select(); $this->assign('consultList', $consultList);// 商品咨询 $this->assign('page', $page);// 赋值分页输出 return $this->fetch(); } /** * 商品评论ajax分页 */ public function ajaxComment() { $goods_id = I("goods_id/d", '0'); $commentType = I('commentType', '1'); // 1 全部 2好评 3 中评 4差评 $where = ['is_show' => 1, 'goods_id' => $goods_id, 'parent_id' => 0]; if ($commentType == 5) { $where['img'] = ['<>', '']; } else { $typeArr = array('1' => '0,1,2,3,4,5', '2' => '4,5', '3' => '3', '4' => '0,1,2'); $where['ceil((deliver_rank + goods_rank + service_rank) / 3)'] = ['in', $typeArr[$commentType]]; } $count = M('Comment')->where($where)->count(); $page = new AjaxPage($count, 10); $show = $page->show(); $list = M('Comment')->alias('c')->join('__USERS__ u', 'u.user_id = c.user_id', 'LEFT')->where($where) ->field('c.*,ceil((deliver_rank + goods_rank + service_rank) / 3) as goods_rank ,u.head_pic') ->order("sort asc , add_time desc")->limit($page->firstRow . ',' . $page->listRows)->select(); // $replyList = M('Comment')->where(['is_show'=>1,'goods_id'=>$goods_id,'parent_id'=>['>',0]])->order("add_time desc")->select(); foreach ($list as $k => $v) { $list[$k]['img'] = unserialize($v['img']); // 晒单图片 $replyList[$v['comment_id']] = M('Comment')->where(['is_show' => 1, 'goods_id' => $goods_id, 'parent_id' => $v['comment_id']])->order("add_time desc")->select(); } $this->assign('commentlist', $list);// 商品评论 $this->assign('replyList', $replyList); // 管理员回复 $this->assign('page', $show);// 赋值分页输出 return $this->fetch(); } /** * 商品咨询 */ public function consult() { $goods_id = input("goods_id/d", '0'); // 商品id $consult_type = input("consult_type", '1'); // 商品咨询类型 $username = input("username", 'TPshop用户'); // 网友咨询 $content = trim(input("content", '')); // 咨询内容 $verify_code = input('verify_code'); if (strlen($content) > 500) { $this->ajaxReturn(['status' => 0, 'msg' => '咨询内容不得超过500字符']); } $verify = new Verify(); if (!$verify->check($verify_code, 'consult')) { $this->ajaxReturn(['status' => 0, 'msg' => '验证码错误']); } $rule = [ ['username', 'require|max:50', '名称不能为空|名称最多不能超过50个字符'], ['content', 'require|max:500', '内容不能为空|名称最多不能超过500个字符'], ]; $data = array( 'goods_id' => $goods_id, 'consult_type' => $consult_type, 'username' => $username, 'content' => $content, 'is_show' => 1, 'add_time' => time(), ); $validate = new Validate($rule); $result = $validate->check($data); if (!$result) { $this->ajaxReturn(['status' => 0, 'msg' => $validate->getError()]); } Db::name('goodsConsult')->add($data); $this->ajaxReturn(['status' => 1, 'msg' => '咨询已提交!']); } /** * 用户收藏商品 */ public function collect_goods() { $goods_ids = I('goods_ids/a', []); if (empty($goods_ids)) { $this->ajaxReturn(['status' => 0, 'msg' => '请至少选择一个商品', 'result' => '']); } $goodsLogic = new GoodsLogic(); $result = []; foreach ($goods_ids as $key => $val) { $result[] = $goodsLogic->collect_goods(cookie('user_id'), $val); } $this->ajaxReturn(['status' => 1, 'msg' => '已添加至我的收藏', 'result' => $result]); } /** * 加入购物车弹出 */ public function open_add_cart() { return $this->fetch(); } /** * 积分商城 */ public function integralMall() { $cat_id = I('get.id/d'); $minValue = I('get.minValue'); $maxValue = I('get.maxValue'); $brandType = I('get.brandType'); //积分规则修改后的逻辑 $point_rate = tpCache('integral.point_rate'); //$point_rate = tpCache('shopping.point_rate'); $is_new = I('get.is_new', 0); $exchange = I('get.exchange', 0); $goods_where = array( 'is_on_sale' => 1, //是否上架 'is_virtual' => 0, ); //积分兑换筛选 $exchange_integral_where_array = array(array('gt', 0)); // 分类id if (!empty($cat_id)) { $goods_where['cat_id'] = array('in', getCatGrandson($cat_id)); } //积分截止范围 if (!empty($maxValue)) { array_push($exchange_integral_where_array, array('elt', $maxValue)); } //积分起始范围 if (!empty($minValue)) { array_push($exchange_integral_where_array, array('egt', $minValue)); } //积分+金额 if ($brandType == 1) { array_push($exchange_integral_where_array, array('exp', ' < shop_price* ' . $point_rate)); } //全部积分 if ($brandType == 2) { array_push($exchange_integral_where_array, array('exp', ' = shop_price* ' . $point_rate)); } //新品 if ($is_new == 1) { $goods_where['is_new'] = $is_new; } //我能兑换 $user_id = cookie('user_id'); if ($exchange == 1 && !empty($user_id)) { $user_pay_points = intval(M('users')->where(array('user_id' => $user_id))->getField('pay_points')); if ($user_pay_points !== false) { array_push($exchange_integral_where_array, array('lt', $user_pay_points)); } } $goods_where['exchange_integral'] = $exchange_integral_where_array; $goods_list_count = M('goods')->where($goods_where)->count(); //总页数 $page = new Page($goods_list_count, 15); $Goods = new \app\common\model\Goods(); $goods_list = $Goods->where($goods_where)->limit($page->firstRow . ',' . $page->listRows)->select(); $goods_category = M('goods_category')->where(array('level' => 1))->select(); $this->assign('goods_list', $goods_list); $this->assign('page', $page->show()); $this->assign('goods_list_count', $goods_list_count); $this->assign('goods_category', $goods_category);//商品1级分类 $this->assign('point_rate', $point_rate);//兑换率 $this->assign('nowPage', $page->nowPage);// 当前页 $this->assign('totalPages', $page->totalPages);//总页数 return $this->fetch(); } /** * 全部商品分类 * @author lxl * @time17-4-18 */ public function all_category() { return $this->fetch(); } /** * 全部品牌列表 * @author lxl * @time17-4-18 */ public function all_brand() { return $this->fetch(); } /** * 获取搭配购列表 * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException */ public function combination() { $goods_id = input('goods_id/d'); $item_id = input('item_id/d', 0); if (empty($goods_id)) { $this->ajaxReturn(['status' => 0, 'msg' => '参数错误']); } $combination = new \app\common\logic\Combination(); $combination_list = []; $combination->setItemId($item_id); $combination->setGoodsId($goods_id); $combination->getGoodCombination(); try { $combination_list = $combination->getCombinationDetails(); } catch (TpshopException $t) { $error = $t->getErrorArr(); $this->ajaxReturn($error); } $this->ajaxReturn(['status' => 1, 'msg' => '获取成功', 'result' => $combination_list]); } }