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.
yanzong/app/store/controller/Goods.php

430 lines
15 KiB

<?php
// +----------------------------------------------------------------------
// | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2017~2023 https://www.yiovo.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
// +----------------------------------------------------------------------
// | Author: 萤火科技 <admin@yiovo.com>
// +----------------------------------------------------------------------
declare (strict_types=1);
namespace app\store\controller;
use think\db\exception\DbException;
use think\response\Json;
use cores\exception\BaseException;
use app\store\model\Goods as GoodsModel;
use app\store\model\goods\Import as ImportModel;
use app\common\model\GoodsCategoryRel;
/**
* 商品管理控制器
* Class Goods
* @package app\store\controller
*/
class Goods extends Controller
{
private static $show_content = "***";
/**
* 商品列表
* @return Json
* @throws DbException
*/
public function list(): Json
{
// 获取列表记录
$model = new GoodsModel;
$params = $this->request->param();
//$params['channel'] = 'zy';
if (!isset($params['merchant_id']) || !$params['merchant_id']) {
$params['merchant_id'] = $this->merchantId;
}
$params['p_store_id'] = $this->storeInfo->p_store_id;
// echo "<pre>";
// print_r($this->storeInfo->p_store_id);
// exit();
$list = $model->getList($params, (int)$this->request->param('pageSize', 15));
if ($list->isEmpty()) {
return $this->renderSuccess(compact('list'));
}
$list = $list->toArray();
foreach ($list['data'] as &$value) {
if (!in_array($value['channel'], ['zy'])) {
// $value['goods_price_min'] = self::$show_content;
// $value['goods_price_max'] = self::$show_content;
// $value['line_price_max'] = self::$show_content;
// $value['line_price_min'] = self::$show_content;
// $value['cost_price_min'] = self::$show_content;
$value['goods_no'] = self::$show_content;
}
}
return $this->renderSuccess(compact('list'));
}
/**
* 根据商品ID集获取列表记录
* @param array $goodsIds
* @return Json
*/
public function listByIds(array $goodsIds): Json
{
// 获取列表记录
$model = new GoodsModel;
$list = $model->getListByIds($goodsIds);
return $this->renderSuccess(compact('list'));
}
/**
* 商品详情(详细信息)
* @param int $goodsId
* @return Json
* @throws BaseException
* @throws \think\db\exception\DataNotFoundException
* @throws DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function detail(int $goodsId): Json
{
// 获取商品详情
$model = new GoodsModel;
$goodsInfo = $model->getDetail($goodsId);
if (!in_array($goodsInfo['channel'], ['zy'])) {
// $goodsInfo['goods_price_min'] = self::$show_content;
// $goodsInfo['goods_price_max'] = self::$show_content;
// $goodsInfo['line_price_max'] = self::$show_content;
// $goodsInfo['line_price_min'] = self::$show_content;
// $goodsInfo['cost_price_min'] = self::$show_content;
$goodsInfo['goods_no'] = self::$show_content;
// foreach ($goodsInfo['skuList'] as $key => &$value) {
// $value['goods_price'] = self::$show_content;
// $value['cost_price'] = self::$show_content;
// }
}
return $this->renderSuccess(compact('goodsInfo'));
}
/**
* 商品详情(基础信息)
* @param int $goodsId
* @return Json
* @throws BaseException
* @throws \think\db\exception\DataNotFoundException
* @throws DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function basic(int $goodsId): Json
{
// 获取商品详情
$model = new GoodsModel;
$detail = $model->getBasic($goodsId);
return $this->renderSuccess(compact('detail'));
}
/**
* 添加商品
* @return Json
* @throws BaseException
* @throws \think\db\exception\DataNotFoundException
* @throws DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function add(): Json
{
$model = new GoodsModel;
$postform = $this->postForm();
$postform['merchant_id'] = $this->merchantId;
if ($model->add($postform)) {
return $this->renderSuccess('添加成功');
}
return $this->renderError($model->getError() ?: '添加失败');
}
/**
* 商品编辑
* @param int $goodsId
* @return Json
* @throws BaseException
* @throws \think\db\exception\DataNotFoundException
* @throws DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function edit(int $goodsId): Json
{
// 商品详情
$model = GoodsModel::detail($goodsId);
$params = $this->postForm();
if ($model->isEmpty()) {
return $this->renderError("该商品已不存在!");
}
if (!in_array($model->channel, ['zy'])) {
$params['goods_price'] = $model->goods_price_min;
$params['cost_price'] = $model->cost_price_min;
$params['goods_no'] = $model->goods_no;
}
// echo "<pre>";
// print_r($params);
// print_r($model->toArray());
// exit();
$params['data_type'] = $model->data_type;
// 更新记录
if ($model->edit($params)) {
return $this->renderSuccess('更新成功');
}
return $this->renderError($model->getError() ?: '更新失败');
}
/**
* 商品入池、出池
* @param array $goodsIds 商品id集
* @param bool $state 为true表示上架
* @return Json
*/
public function pool(array $goodsIds, bool $state): Json
{
$model = new GoodsModel;
//过滤其他渠道的商品,只能把自营商品加入商品池
$list = GoodsModel::whereIn('goods_id', $goodsIds)->where('channel','zy')->select();
if (!$list) {
return $this->renderError("没有需要加入商品池的自营商品");
}
$goodsIds = array_column($list->toArray(), "goods_id");
$state = $state ? 1 : 2;
if (!$model->setIsPool($goodsIds, $state)) {
return $this->renderError($model->getError() ?: '操作失败');
}
return $this->renderSuccess('操作成功');
}
/**
* 修改商品状态(上下架)
* @param array $goodsIds 商品id集
* @param bool $state 为true表示上架
* @return Json
*/
public function state(array $goodsIds, bool $state): Json
{
$model = new GoodsModel;
if (!$model->setStatus($goodsIds, $state)) {
return $this->renderError($model->getError() ?: '操作失败');
}
return $this->renderSuccess('操作成功');
}
/**
* 修改商品状态(上下架)
* @param array $goodsIds 商品id集
* @param bool $state 为true表示上架
* @return Json
*/
public function setBrand(array $goodsIds, bool $is_brand): Json
{
$model = new GoodsModel;
if (!$model->setBrand($goodsIds, $is_brand)) {
return $this->renderError($model->getError() ?: '操作失败');
}
return $this->renderSuccess('操作成功');
}
/**
* 修改商品状态(上下架)
* @param array $goodsIds 商品id集
* @param bool $state 为true表示上架
* @return Json
*/
public function setNew(array $goodsIds, bool $is_new): Json
{
$model = new GoodsModel;
if (!$model->setNew($goodsIds, $is_new)) {
return $this->renderError($model->getError() ?: '操作失败');
}
return $this->renderSuccess('操作成功');
}
/**
* 修改商品状态(上下架)
* @param array $goodsIds 商品id集
* @param bool $state 为true表示上架
* @return Json
*/
public function setInstore(array $goodsIds, bool $is_in_store): Json
{
$model = new GoodsModel;
if (!$model->setInstore($goodsIds, $is_in_store)) {
return $this->renderError($model->getError() ?: '操作失败');
}
return $this->renderSuccess('操作成功');
}
/**
* 修改商品状态(上下架)
* @param array $goodsIds 商品id集
* @param bool $state 为true表示上架
* @return Json
*/
public function setRank(array $goodsIds, int $paihang): Json
{
$model = new GoodsModel;
if (!$model->setRank($goodsIds, $paihang)) {
return $this->renderError($model->getError() ?: '操作失败');
}
return $this->renderSuccess('操作成功');
}
/**
* 商品归类
* @param array $goodsIds 商品id集
* @param bool $state 为true表示上架
* @return Json
*/
public function category(array $goodsIds, array $categoryIds): Json
{
$model = new GoodsModel;
foreach ($goodsIds as $key => $goodsId) {
$categoryIds = $model->dealCategory($categoryIds);
\app\store\model\GoodsCategoryRel::updates($goodsId, $categoryIds);
}
$model->whereIn('goods_id', $goodsIds)->update(['cate_status'=>1,'update_time' => time()]);
return $this->renderSuccess('操作成功');
}
/**
* 删除商品
* @param array $goodsIds
* @return Json
*/
public function delete(array $goodsIds): Json
{
$model = new GoodsModel;
if (!$model->setDelete($goodsIds)) {
return $this->renderError($model->getError() ?: '删除失败');
}
// 分批每次导入20条
$limit = 20;
// 根据商品总数量计算需要的队列任务数量
$jobCount = \count($goodsIds) / $limit;
// 逐次发布队列任务
for ($i = 0; $i < $jobCount; $i++) {
$data = array_slice($goodsIds, $i * $limit, $limit);
StoreGoodsDeleteJob::dispatch([
'list' => $data,
]);
}
return $this->renderSuccess('删除成功');
}
public function export(){
ini_set('memory_limit', '2024M');
set_time_limit(0);
$model = new GoodsModel;
$params = $this->request->param();
$params['store_id'] = $this->storeId;
$perSize = 10000;
$params['page'] = 1;
if ($this->merchantId) {
$params['merchantId'] = $this->merchantId;
}
//$params['channels'] = ['zy'];
// echo "<pre>";
// print_r($params);
//exit();
$data = $model->getAdminListExport($params, $perSize)->toArray();
// echo "<pre>";
// print_r($data['data']);
// exit();
if ($data['data']) {
foreach ($data['data'] as &$value) {
if (!in_array($value['channel'], ['zy'])) {
$value['goods_price_min'] = self::$show_content;
$value['goods_price_max'] = self::$show_content;
$value['line_price_max'] = self::$show_content;
$value['line_price_min'] = self::$show_content;
$value['cost_price_min'] = self::$show_content;
$value['goods_no'] = self::$show_content;
}
$cates = GoodsCategoryRel::where('goods_id', $value['goods_id'])->select()->toArray();
$value['category_id'] = $cates ? implode(",", array_column($cates, "category_id")) : "";
}
}
// echo "<pre>";
// print_r($data);
// exit();
$titles = [
['goods_id'=>'系统编码(禁止修改)'],
['goods_name'=>'标题'],
['cmmdty_model'=>'商品型号'],
['goods_source'=>'商品来源(GC:工厂 CC:仓储 ZC:自采 填其中一项)'],
['goods_no'=>'商品编码(电商平台同款编码)'],
['category_id'=>'分类(填写1级到现有分类代码,中间用英文小写的逗号分开)'],
['delivery_time'=>'发货时效(0:24小时 1:48小时 3:72小时 4:7天内 5:15天内 6:30天内 7:45天内 填写其中一项)'],
['is_check'=>'是否审单(是填1 否填0)'],
['delivery_id'=>'运费模板ID'],
['status'=>'商品状态 (下架填写20 上架填写10)'],
['cost_price_min'=>'成本价'],
['goods_price_min'=>'前台价'],
['stock_total'=>'库存量'],
// ['stock_total'=>'库存量'],
['remark'=>'下单须知'],
['is_use_jd_stock'=>'是否使用京东库存(是填1 否填0)'],
];
downLoadExcel('导出数据-'.date('Y-m-d', time()),$titles,$data['data']);
}
public function import(){
// 新增记录
$model = new ImportModel;
$params = $this->postData();
$params['channel'] = "zy";
if ($model->storeGoodsUpdateBatch($params)) {
return $this->renderSuccess('批量修改成功');
}
return $this->renderError($model->getError() ?: '操作失败');
}
/**
* 商品抓取
* [collector description]
* @return [type] [description]
*/
public function collector(string $sku): Json{
$res = getJdGoodsBySku([$sku]);
if (!$res) {
return $this->renderError('数据抓取失败');
}
// $collector = new \app\job\service\goods\Collector;
// $url = "https://item.jd.com/{$sku}.html";
// $res1 = $collector->collector($url, 10048);
return $this->renderSuccess($res[$sku] ?? []);
}
//商品一键上架
public function oneClickShelf(): Json{
$model = new GoodsModel;
GoodsModel::update(['status'=>10]);
return $this->renderSuccess('操作成功');
}
public function oneClickOffTheShelf(): Json{
$model = new GoodsModel;
GoodsModel::update(['status'=>20]);
return $this->renderSuccess('操作成功');
}
/**
* 修改商品状态(上下架)
* @param array $goodsIds 商品id集
* @param bool $state 为true表示上架
* @return Json
*/
public function jingpin(array $goodsIds, int $is_jingpin): Json
{
$model = new GoodsModel;
if (!$model->setIsJingpin($goodsIds, $is_jingpin)) {
return $this->renderError($model->getError() ?: '操作失败');
}
return $this->renderSuccess('操作成功');
}
}