params[ 'sku_id' ]) ? $this->params[ 'sku_id' ] : 0; $goods_id = isset($this->params[ 'goods_id' ]) ? $this->params[ 'goods_id' ] : 0; $goods = new CardGoods(); if (empty($sku_id) && !empty($goods_id)) { $sku_id = $goods->getGoodsInfo([ [ 'goods_id', '=', $goods_id ] ], 'sku_id')[ 'data' ][ 'sku_id' ] ?? 0; } if (empty($sku_id) && empty($goods_id)) { return $this->response($this->error('', 'REQUEST_ID')); } $goods_sku_detail = $goods->getGoodsSkuDetail($sku_id, $this->site_id, "")['data']; if (empty($goods_sku_detail)) return $this->response($this->error()); $goods_sku_detail[ 'purchased_num' ] = 0; // 该商品已购数量 $res[ 'goods_sku_detail' ] = $goods_sku_detail; // 商品服务 $goods_service = new GoodsService(); $goods_config_model = new GoodsConfigModel(); $goods_service_list = $goods_service->getServiceList([ [ 'site_id', '=', $this->site_id ], [ 'id', 'in', $res[ 'goods_sku_detail' ][ 'goods_service_ids' ] ] ], 'service_name,desc,icon'); $content = $goods_config_model->getAfterSaleConfig($this->site_id); //获取注册协议 $config_model = new \app\model\order\Config(); $document_info = $config_model->getTransactionDocument(1, 'shop'); $res[ 'goods_sku_detail' ][ 'goods_service' ] = $goods_service_list[ 'data' ]; $res[ 'goods_sku_detail' ][ 'goods_aftersale' ] = $content[ 'data' ]['content']; $res[ 'goods_sku_detail' ][ 'transactionagreement' ] = $document_info['data']['content']; $res[ 'goods_sku_detail' ][ 'zhima_aftersale' ] = $document_info['data']['content']; return $this->response($this->success($res)); } /** * 列表信息 */ public function page() { $page = isset($this->params[ 'page' ]) ? $this->params[ 'page' ] : 1; $page_size = isset($this->params[ 'page_size' ]) ? $this->params[ 'page_size' ] : PAGE_LIST_ROWS; $goods_id_arr = isset($this->params[ 'goods_id_arr' ]) ? $this->params[ 'goods_id_arr' ] : '';//goods_id数组 $keyword = isset($this->params[ 'keyword' ]) ? trim($this->params[ 'keyword' ]) : '';//关键词 $service_category = isset($this->params[ 'service_category' ]) ? $this->params[ 'service_category' ] : 0;//分类 $is_free_shipping = isset($this->params[ 'is_free_shipping' ]) ? $this->params[ 'is_free_shipping' ] : 0;//是否免邮 $order = isset($this->params[ 'order' ]) ? $this->params[ 'order' ] : "";//排序(综合、销量、价格) $sort = isset($this->params[ 'sort' ]) ? $this->params[ 'sort' ] : "";//升序、降序 $card_type = isset($this->params[ 'card_type' ]) ? $this->params[ 'card_type' ] : ''; $condition = []; $condition[] = [ 'gs.site_id', '=', $this->site_id ]; //$condition[] = [ 'g.goods_class', '=', (new CardGoods())->getGoodsClass()['id'] ]; $condition[] = [ 'g.goods_class', 'in', [2,5] ]; if (!empty($goods_id_arr)) { $condition[] = [ 'gs.goods_id', 'in', $goods_id_arr ]; } if (!empty($card_type)) { $condition[] = [ 'gc.card_type', '=', $card_type ]; } if (!empty($service_category)) { $condition[] = [ 'g.service_category', 'like', '%,'.$service_category.',%' ]; } if (!empty($keyword)) { $condition[] = [ 'g.goods_name|gs.sku_name|gs.keywords', 'like', '%' . $keyword . '%' ]; } if (!empty($is_free_shipping)) { $condition[] = [ 'gs.is_free_shipping', '=', $is_free_shipping ]; } // 非法参数进行过滤 if ($sort != "desc" && $sort != "asc") { $sort = ""; } // 非法参数进行过滤 if ($order != '') { if ($order != "sale_num" && $order != "discount_price") { $order = 'gs.sort'; } elseif ($order == "sale_num") { $order = 'sale_sort'; } else { $order = 'gs.' . $order; } $order_by = $order . ' ' . $sort; } else { $config_model = new ConfigModel(); $sort_config = $config_model->getGoodsSort($this->site_id); $sort_config = $sort_config[ 'data' ][ 'value' ]; $order_by = 'g.sort ' . $sort_config[ 'type' ] . ',g.create_time desc'; } $condition[] = [ 'g.goods_state', '=', 1 ]; $condition[] = [ 'g.is_delete', '=', 0 ]; $alias = 'gs'; $field = 'g.goods_class,gs.is_consume_discount,gs.discount_config,gs.discount_method,gs.member_price,gs.goods_id,gs.sort,gs.sku_id,gs.sku_name,gs.price,gs.market_price,gs.discount_price,gs.stock,(g.sale_num + g.virtual_sale) as sale_num,(gs.sale_num + gs.virtual_sale) as sale_sort,gs.sku_image,gs.goods_name,gs.site_id,gs.is_free_shipping,gs.introduction,gs.promotion_type,g.goods_image,g.promotion_addon,gs.is_virtual,g.goods_spec_format,g.recommend_way,gs.max_buy,gs.min_buy,gs.unit,gs.is_limit,gs.limit_type,g.label_name,g.stock_show,g.sale_show,g.market_price_show,g.barrage_show,g.sale_channel,g.sale_store, gc.card_type,gc.card_type_name,gc.renew_price,gc.recharge_money,gc.common_num,gc.discount_goods_type,gc.discount,gc.validity_type,gc.validity_day,gc.validity_time'; $join = [ [ 'goods g', 'gs.sku_id = g.sku_id', 'inner' ], [ 'goods_card gc', 'gc.goods_id=gs.goods_id','left'], ]; $goods = new Goods(); $list = $goods->getGoodsSkuPageList($condition, $page, $page_size, $order_by, $field, $alias, $join); return $this->response($list); } public function getCardListByType() { $goods = new CardGoods(); $list = $goods->getCardType(); $condition = [ [ 'gs.site_id', '=', $this->site_id ], [ 'g.goods_class', '=', $goods->getGoodsClass()['id'] ], [ 'g.goods_state', '=', 1 ], [ 'g.is_delete', '=', 0 ] ]; $field = 'gs.is_consume_discount,gs.discount_config,gs.discount_method,gs.member_price,gs.goods_id,gs.sort,gs.sku_id,gs.sku_name,gs.price,gs.market_price,gs.discount_price,gs.stock,(g.sale_num + g.virtual_sale) as sale_num,(gs.sale_num + gs.virtual_sale) as sale_sort,gs.sku_image,gs.goods_name,gs.site_id,gs.is_free_shipping,gs.introduction,gs.promotion_type,g.goods_image,g.promotion_addon,gs.is_virtual,g.goods_spec_format,g.recommend_way,gs.max_buy,gs.min_buy,gs.unit,gs.is_limit,gs.limit_type,g.label_name,g.stock_show,g.sale_show,g.market_price_show,g.barrage_show,g.sale_channel,g.sale_store, gc.card_type,gc.card_type_name,gc.renew_price,gc.recharge_money,gc.common_num,gc.discount_goods_type,gc.discount,gc.validity_type,gc.validity_day,gc.validity_time'; $join = [ [ 'goods_sku gs', 'gs.sku_id = g.sku_id', 'inner' ], [ 'goods_card gc', 'gc.goods_id=gs.goods_id','left'], ]; $card_list = $goods->getGoodsList($condition, $field, 'g.sort asc', 'g', $join); foreach ($list as $k => $v){ $list[$k]['card_list'] = []; foreach ($card_list['data'] as $key => $val){ if($val['card_type'] == $v['type']){ $list[$k]['card_list'][] = $val; } } if(empty($list[$k]['card_list'])) unset($list[$k]); } return $this->response($this->success($list)); } }