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.
shipin/app/api/controller/pc/ProductController.php

132 lines
4.7 KiB

10 months ago
<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
namespace app\api\controller\pc;
use app\Request;
use app\services\pc\ProductServices;
use app\services\product\product\StoreCategoryServices;
use app\services\product\product\StoreProductServices;
class ProductController
{
protected $services;
public function __construct(ProductServices $services)
{
$this->services = $services;
}
/**
* 获取商品列表
* @param Request $request
* @param StoreCategoryServices $services
* @return mixed
*/
public function getProductList(Request $request, StoreCategoryServices $services)
{
$where = $request->getMore([
[['sid', 'd'], 0],
[['cid', 'd'], 0],
['keyword', '', '', 'store_name'],
['priceOrder', ''],
['salesOrder', ''],
[['news', 'd'], 0, '', 'timeOrder'],
[['type', 0], 0],
['ids', ''],
['selectId', '']
]);
if ($where['selectId'] && (!$where['sid'] || !$where['cid'])) {
if ($services->value(['id' => $where['selectId']], 'pid')) {
$where['sid'] = $where['selectId'];
} else {
$where['cid'] = $where['selectId'];
}
}
if ($where['ids'] && is_string($where['ids'])) {
$where['ids'] = explode(',', $where['ids']);
}
if (!$where['ids']) {
unset($where['ids']);
}
return app('json')->success($this->services->getProductList($where, $request->uid()));
}
/**
* PC端商品详情小程序码
* @param Request $request
* @return mixed
*/
public function getProductRoutineCode(Request $request)
{
list($product_id, $type) = $request->getMore([
['product_id', 0],
['type', 'product'],
], true);
$routineCode = $this->services->getProductRoutineCode((int)$product_id, $type);
return app('json')->success(['routineCode' => $routineCode]);
}
/**
* 推荐商品
* @param Request $request
* @param $type
* @return mixed
*/
public function getRecommendList(Request $request, $type)
{
/** @var StoreProductServices $product */
$product = app()->make(StoreProductServices::class);
$data = [];
$data['list'] = [];
$where['is_show'] = 1;
$where['is_del'] = 0;
if ($type == 1) {//TODO 精品推荐
$data['list'] = $product->getRecommendProduct($request->uid(), 'is_best', 0, 'mid');//TODO 精品推荐个数
$where['is_best'] = 1;
} else if ($type == 2) {//TODO 热门榜单
$data['list'] = $product->getRecommendProduct($request->uid(), 'is_hot', 0, 'mid');//TODO 热门榜单 猜你喜欢
$where['is_hot'] = 1;
} else if ($type == 3) {//TODO 首发新品
$data['list'] = $product->getRecommendProduct($request->uid(), 'is_new', 0, 'mid');//TODO 首发新品
$where['is_new'] = 1;
} else if ($type == 4) {//TODO 促销单品
$data['list'] = $product->getRecommendProduct($request->uid(), 'is_benefit', 0, 'mid');//TODO 促销单品
$where['is_benefit'] = 1;
}
foreach ($data['list'] as &$item) {
if (count($item['star'])) {
$item['star'] = bcdiv((string)array_sum(array_column($item['star'], 'product_score')), (string)count($item['star']), 1);
} else {
$item['star'] = '3.0';
}
}
$data['count'] = $product->getCount($where);
return app('json')->success($data);
}
/**
* 获取优品推荐
* @return mixed
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function getGoodProduct()
{
/** @var StoreProductServices $product */
$product = app()->make(StoreProductServices::class);
$list = get_thumb_water($product->getProducts(['is_good' => 1, 'is_del' => 0, 'is_show' => 1]), 'mid');
return app('json')->success(compact('list'));
}
}