徐总多门店
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.
 
 
 
 
 
 

836 lines
25 KiB

<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2020 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
namespace app\controller\admin\v1\product;
use app\controller\admin\AuthController;
use app\jobs\BatchHandleJob;
use app\jobs\product\ProductSyncErp;
use app\services\other\CacheServices;
use app\services\other\queue\QueueServices;
use app\services\product\category\StoreProductCategoryServices;
use app\services\product\product\StoreProductBatchProcessServices;
use app\services\product\product\StoreProductServices;
use app\services\product\sku\StoreProductAttrServices;
use app\services\product\sku\StoreProductAttrValueServices;
use crmeb\services\FileService;
use crmeb\services\SpreadsheetExcelService;
use crmeb\services\UploadService;
use think\facade\App;
/**
* Class StoreProduct
* @package app\controller\admin\v1\product
*/
class StoreProduct extends AuthController
{
protected $service;
public function __construct(App $app, StoreProductServices $service)
{
parent::__construct($app);
$this->service = $service;
}
/**
* 显示资源列表头部
* @return mixed
*/
public function type_header(StoreProductCategoryServices $storeProductCategoryServices)
{
$where = $this->request->getMore([
['store_name', ''],
['cate_id', ''],
['supplier_id', ''],
['type', 1, '', 'status'],
['store_id', ''],
['store_label_id', ''],
['brand_id', '']
]);
$cateId = $where['cate_id'];
if ($cateId) {
$cateId = is_string($cateId) ? [$cateId] : $cateId;
$cateId = array_merge($cateId, $storeProductCategoryServices->getColumn(['pid' => $cateId], 'id'));
$cateId = array_unique(array_diff($cateId, [0]));
}
$where['cate_id'] = $cateId;
$list = $this->service->getHeader(0, $where);
return $this->success(compact('list'));
}
/**
* 获取退出未保存的数据
* @param CacheServices $services
* @return mixed
*/
public function getCacheData(CacheServices $services)
{
return $this->success(['info' => $services->getDbCache($this->adminId . '_product_data', [])]);
}
/**
* 1分钟保存一次产品数据
* @param CacheServices $services
* @return mixed
*/
public function saveCacheData(CacheServices $services)
{
$data = $this->request->postMore([
['product_type', 0],//商品类型
['supplier_id', 0],//供应商ID
['cate_id', []],
['store_name', ''],
['store_info', ''],
['keyword', ''],
['unit_name', '件'],
['recommend_image', ''],
['slider_image', []],
['is_sub', []],//佣金是单独还是默认
['sort', 0],
['sales', 0],
['ficti', 0],
['give_integral', 0],
['is_show', 0],
['is_hot', 0],
['is_benefit', 0],
['is_best', 0],
['is_new', 0],
['mer_use', 0],
['is_postage', 0],
['is_good', 0],
['description', ''],
['spec_type', 0],
['video_open', 0],//是否开启视频
['video_link', ''],//视频链接
['items', []],
['attrs', []],
['activity', []],
['coupon_ids', []],
['label_id', []],
['command_word', ''],
['tao_words', ''],
['type', 0],
['delivery_type', []],//物流设置
['freight', 1],//运费设置
['postage', 0],//邮费
['temp_id', 0],//运费模版
['recommend_list', []],
['brand_id', []],
['soure_link', ''],
['bar_code', ''],
['code', ''],
['is_support_refund', 1],//是否支持退款
['is_presale_product', 0],//预售商品开关
['presale_time', []],//预售时间
['presale_day', 0],//预售发货日
['is_vip_product', 0],//是否付费会员商品
['auto_on_time', 0],//自动上架时间
['auto_off_time', 0],//自动下架时间
['custom_form', []],//自定义表单
['system_form_id', 0],//系统表单ID
['store_label_id', []],//商品标签
['ensure_id', []],//商品保障服务区
['specs', []],//商品参数
['specs_id', 0],//商品参数ID
['is_limit', 0],//是否限购
['limit_type', 0],//限购类型
['limit_num', 0],//限购数量
['applicable_type', 1],//适用门店类型
['applicable_store_id', []],//适用门店IDS
]);
$services->setDbCache($this->adminId . '_product_data', $data, 68400);
return $this->success();
}
/**
* 删除数据缓存
* @param CacheServices $services
* @return mixed
*/
public function deleteCacheData(CacheServices $services)
{
$services->delectDbCache($this->adminId . '_product_data');
return $this->success();
}
/**
* 显示资源列表
* @return mixed
*/
public function index(StoreProductCategoryServices $storeProductCategoryServices)
{
$where = $this->request->getMore([
['store_name', ''],
['cate_id', ''],
['supplier_id', 0],
['type', 1, '', 'status'],
['sales', 'normal'],
['store_id', 0],
['store_label_id', ''],
['brand_id', '']
]);
if ($where['supplier_id']) {
$where['relation_id'] = $where['supplier_id'];
$where['type'] = 2;
} elseif ($where['store_id']) {
$where['relation_id'] = $where['store_id'];
$where['type'] = 1;
} else {
$where['pid'] = 0;
}
$cateId = $where['cate_id'];
if ($cateId) {
$cateId = is_string($cateId) ? [$cateId] : $cateId;
$cateId = array_merge($cateId, $storeProductCategoryServices->getColumn(['pid' => $cateId], 'id'));
$cateId = array_unique(array_diff($cateId, [0]));
}
$where['cate_id'] = $cateId;
unset($where['supplier_id'], $where['store_id']);
$data = $this->service->getList($where);
return $this->success($data);
}
/**
* 审核商品表单
* @param $id
* @return mixed
*/
public function verifyForm($id)
{
if (!$id) {
return $this->fail('缺少参数');
}
return $this->success($this->service->verifyForm($id));
}
/**
* 强制下架表单
* @param $id
* @return mixed
*/
public function removeForm($id)
{
if (!$id) {
return $this->fail('缺少参数');
}
return $this->success($this->service->verifyForm($id, 2));
}
/**
* 审核商品
* @param string $is_show
* @param string $id
* @return mixed
*/
public function setVerify($id = '')
{
if (!$id) {
return $this->fail('缺少参数');
}
$data = $this->request->getMore([
['is_verify', 1],
['refusal', '']
]);
if (in_array($data['is_verify'], [-1, -2]) && !$data['refusal']) {
return $this->fail('请输入原因');
}
$this->service->verify((int)$id, $data);
return $this->success('审核成功');
}
/**
* 修改状态
* @param string $is_show
* @param string $id
* @return mixed
*/
public function set_show($is_show = '', $id = '')
{
$this->service->setShow([$id], $is_show);
return $this->success($is_show == 1 ? '上架成功' : '下架成功');
}
/**
* 设置批量商品上架
* @return mixed
*/
public function product_show()
{
[$ids, $all, $where] = $this->request->postMore([
['ids', []],
['all', 0],
['where', []],
], true);
if ($all == 0) {//单页不走队列
if (empty($ids)) return $this->fail('请选择需要上架的商品');
$this->service->setShow($ids, 1);
return $this->success('上架成功');
} else {//全部
$ids = [];
if (isset($where['type'])) {
$where['status'] = $where['type'];
unset($where['type']);
}
$type = 4;//商品上架
/** @var QueueServices $queueService */
$queueService = app()->make(QueueServices::class);
$queueService->setQueueData($where, 'id', $ids, $type);
//加入队列
BatchHandleJob::dispatch(['up', $type]);
return $this->success('后台程序已执商品上架任务!');
}
}
/**
* 设置批量商品下架
* @return mixed
*/
public function product_unshow()
{
[$ids, $all, $where] = $this->request->postMore([
['ids', []],
['all', 0],
['where', []],
], true);
if ($all == 0) {//单页不走队列
if (empty($ids)) return $this->fail('请选择需要下架的商品');
$this->service->setShow($ids, 0);
return $this->success('下架成功');
} else {//全部
$ids = [];
if (isset($where['type'])) {
$where['status'] = $where['type'];
unset($where['type']);
}
$type = 4;//商品下架
/** @var QueueServices $queueService */
$queueService = app()->make(QueueServices::class);
$queueService->setQueueData($where, 'id', $ids, $type);
//加入队列
BatchHandleJob::dispatch(['down', $type]);
return $this->success('后台程序已执商品下架任务!');
}
}
/**
* 批量设置商品配送方式
* @return mixed
*/
public function setProductDeliveryType()
{
[$ids, $all, $deliveryType] = $this->request->postMore([
['ids', []],
['all', 0],
['delivery_type', []],
], true);
if (!$deliveryType) {
return $this->fail('请选择配送方式');
}
if ($all == 0 && empty($ids)) {
return $this->fail('请选择需要设置的商品');
}
if (count($ids) == 1) {
$product = $this->service->get($ids[0]);
if ($product && in_array($product['product_type'], [1, 2, 3])) {
return $this->fail('虚拟、卡密商品不需要设置配送方式');
}
}
if ($all == 1) {
$update_where = ['is_show' => 1, 'is_del' => 0];
} else {
$update_where = [['id', 'in', $ids]];
}
if (!$this->service->update($update_where, ['delivery_type' => $deliveryType])) {
return $this->fail('设置失败');
}
$this->service->cacheTag()->clear();
return $this->success('设置成功');
}
/**
* 批量设置商品标签
* @return mixed
*/
public function setProductlabel()
{
[$ids, $all, $store_label_id] = $this->request->postMore([
['ids', []],
['all', 0],
['store_label_id', []],
], true);
if (!$store_label_id) {
return $this->fail('请选择商品标签');
}
if ($all == 0 && empty($ids)) {
return $this->fail('请选择需要设置的商品');
}
if ($all == 1) {
$update_where = ['is_show' => 1, 'is_del' => 0];
} else {
$update_where = [['id', 'in', $ids]];
}
if (!$this->service->update($update_where, ['store_label_id' => implode(',', $store_label_id)])) {
return $this->fail('设置失败');
}
$this->service->cacheTag()->clear();
return $this->success('设置成功');
}
/**
* 批量设置商品保障服务
* @return mixed
*/
public function setProductEnsure()
{
[$ids, $all, $ensure_id] = $this->request->postMore([
['ids', []],
['all', 0],
['store_label_id', []],
], true);
if (!$ensure_id) {
return $this->fail('请选择商品保障服务');
}
if ($all == 0 && empty($ids)) {
return $this->fail('请选择需要设置的商品');
}
if ($all == 1) {
$update_where = ['is_show' => 1, 'is_del' => 0];
} else {
$update_where = [['id', 'in', $ids]];
}
if (!$this->service->update($update_where, ['ensure_id' => implode(',', $ensure_id)])) {
return $this->fail('设置失败');
}
$this->service->cacheTag()->clear();
return $this->success('设置成功');
}
/**
* 批量设置商品参数
* @return mixed
*/
public function setProductSpecs()
{
[$ids, $all, $specs_id, $specs] = $this->request->postMore([
['ids', []],
['all', 0],
['specs_id', 0],
['specs', []],
], true);
if (!$specs_id) {
return $this->fail('请选择商品参数模版');
}
if (!$specs) {
return $this->fail('请添加商品参数');
}
if ($all == 0 && empty($ids)) {
return $this->fail('请选择需要设置的商品');
}
if ($all == 1) {
$update_where = ['is_show' => 1, 'is_del' => 0];
} else {
$update_where = [['id', 'in', $ids]];
}
if (!$this->service->update($update_where, ['specs_id' => $specs_id, 'specs' => json_encode($specs)])) {
return $this->fail('设置失败');
}
$this->service->cacheTag()->clear();
return $this->success('设置成功');
}
/**
* 获取规格模板
* @return mixed
*/
public function get_rule()
{
return $this->success($this->service->getRule());
}
/**
* 获取商品详细信息
* @param int $id
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function get_product_info($id = 0)
{
return $this->success($this->service->getInfo((int)$id));
}
/**
* 保存新建或编辑
* @param $id
* @return mixed
* @throws \Exception
*/
public function save(StoreProductAttrServices $attrServices, $id)
{
$data = $this->request->postMore([
['product_type', 0],//商品类型
['supplier_id', 0],//供应商ID
['cate_id', []],
['store_name', ''],
['store_info', ''],
['keyword', ''],
['unit_name', '件'],
['recommend_image', ''],
['slider_image', []],
['is_sub', []],//佣金是单独还是默认
['sort', 0],
// ['sales', 0],
['ficti', 0],
['give_integral', 0],
['is_show', 0],
['is_hot', 0],
['is_benefit', 0],
['is_best', 0],
['is_new', 0],
['mer_use', 0],
['is_postage', 0],
['is_good', 0],
['description', ''],
['spec_type', 0],
['video_open', 0],
['video_link', ''],
['items', []],
['attrs', []],
['recommend', []],//商品推荐
['activity', []],
['coupon_ids', []],
['label_id', []],
['command_word', ''],
['tao_words', ''],
['type', 0, '', 'is_copy'],
['delivery_type', []],//物流设置
['freight', 1],//运费设置
['postage', 0],//邮费
['temp_id', 0],//运费模版
['recommend_list', []],
['brand_id', []],
['soure_link', ''],
['bar_code', ''],
['code', ''],
['is_support_refund', 1],//是否支持退款
['is_presale_product', 0],//预售商品开关
['presale_time', []],//预售时间
['presale_day', 0],//预售发货日
['is_vip_product', 0],//是否付费会员商品
['auto_on_time', 0],//自动上架时间
['auto_off_time', 0],//自动下架时间
['custom_form', []],//自定义表单
['system_form_id', 0],//系统表单ID
['store_label_id', []],//商品标签
['ensure_id', []],//商品保障服务区
['specs', []],//商品参数
['specs_id', 0],//商品参数ID
['is_limit', 0],//是否限购
['limit_type', 0],//限购类型
['limit_num', 0],//限购数量
['applicable_type', 1],//适用门店类型
['applicable_store_id', []],//适用门店IDS
]);
if ($data['applicable_type'] == 1) {
$data['applicable_store_id'] = [];
} elseif ($data['applicable_type'] == 2) {
if (!$data['applicable_store_id']) {
return $this->fail('请选择要适用门店');
}
}
$this->service->save((int)$id, $data);
$this->service->cacheTag()->clear();
$attrServices->cacheTag()->clear();
return $this->success($id ? '保存商品信息成功' : '添加商品成功!');
}
/**
* 删除指定资源
*
* @param int $id
* @return \think\Response
*/
public function delete(StoreProductAttrServices $attrServices, $id)
{
//删除商品检测是否有参与活动
$this->service->checkActivity($id);
$res = $this->service->del($id);
event('product.delete', [$id]);
$this->service->cacheTag()->clear();
$attrServices->cacheTag()->clear();
return $this->success($res);
}
/**
* 生成规格列表
* @param int $id
* @param int $type
* @return mixed
*/
public function is_format_attr($id = 0, $type = 0)
{
$data = $this->request->postMore([
['attrs', []],
['items', []],
['product_type', 0]
]);
if ($id > 0 && $type == 1) $this->service->checkActivity($id);
$plat_type = 0;
$relation_id = 0;
if ((int)$id) {//编辑 需要查看商品来源
$productInfo = $this->service->get((int)$id, ['id', 'type', 'relation_id']);
if (!$productInfo) {
return $this->fail('商品不存在');
}
$plat_type = (int)$productInfo['type'];
$relation_id = (int)$productInfo['relation_id'];
}
$info = $this->service->getAttr($data, $id, $type, $plat_type, $relation_id);
return $this->success(compact('info'));
}
/**
* 获取选择的商品列表
* @return mixed
*/
public function search_list()
{
$where = $this->request->getMore([
['ids', ''],
['cate_id', ''],
['store_name', ''],
['type', 1, '', 'status'],
['is_live', 0],
['is_new', ''],
['is_vip_product', ''],
['is_presale_product', ''],
['store_label_id', ''],
['is_supplier', -1],//供应商商品0:不是1:是
['is_integral', 0],//活动不要次卡商品
]);
$where['is_show'] = 1;
$where['is_del'] = 0;
$where['is_verify'] = 1;
/** @var StoreProductCategoryServices $storeCategoryServices */
$storeCategoryServices = app()->make(StoreProductCategoryServices::class);
if ($where['cate_id'] !== '') {
if ($storeCategoryServices->value(['id' => $where['cate_id']], 'pid')) {
$where['sid'] = $where['cate_id'];
} else {
$where['cid'] = $where['cate_id'];
}
}
$where['type'] = [0, 2];
if ($where['is_supplier'] == 1) {
$where['type'] = [2];
} elseif($where['is_supplier'] == 0) {
$where['type'] = [0];
}
unset($where['cate_id'], $where['is_supplier']);
$list = $this->service->searchList($where);
return $this->success($list);
}
/**
* 获取某个商品规格
* @return mixed
*/
public function get_attrs()
{
[$id, $type] = $this->request->getMore([
[['id', 'd'], 0],
[['type', 'd'], 0],
], true);
$info = $this->service->getProductRules($id, $type);
return $this->success(compact('info'));
}
/**
* 获取运费模板列表
* @return mixed
*/
public function get_template()
{
[$id] = $this->request->getMore([
[['id', 'd'], 0],
], true);
$type = $relation_id = 0;
if ((int)$id) {
$info = $this->service->get((int)$id, ['id', 'type', 'relation_id']);
if ($info) {
$type = (int)$info['type'];
$relation_id = (int)$info['relation_id'];
}
}
return $this->success($this->service->getTemp($type, $relation_id));
}
/**
* 获取视频上传token
* @return mixed
* @throws \Exception
*/
public function getTempKeys()
{
$upload = UploadService::init();
$type = (int)sys_config('upload_type', 1);
$key = $this->request->get('key', '');
$path = $this->request->get('path', '');
$contentType = $this->request->get('contentType', '');
if ($type === 5) {
if (!$key || !$contentType) {
return app('json')->fail('缺少参数');
}
$re = $upload->getTempKeys($key, $path, $contentType);
} else {
$re = $upload->getTempKeys();
}
return $re ? $this->success($re) : $this->fail($upload->getError());
}
/**
* 检测商品是否开活动
* @param $id
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function check_activity($id)
{
$this->service->checkActivity($id);
return $this->success('删除成功');
}
/**
* 获取商品所有规格数据
* @param StoreProductAttrValueServices $services
* @param $id
* @return mixed
*/
public function getAttrs(StoreProductAttrValueServices $services, $id)
{
if (!$id) {
return $this->fail('缺少商品ID');
}
return $this->success($services->getProductAttrValue(['product_id' => $id, 'type' => 0]));
}
/**
* 快速修改商品规格库存
* @param StoreProductAttrValueServices $services
* @param $id
* @return mixed
*/
public function saveProductAttrsStock(StoreProductAttrValueServices $services, $id)
{
if (!$id) {
return $this->fail('缺少商品ID');
}
[$attrs] = $this->request->getMore([
['attrs', []]
], true);
if (!$attrs) {
return $this->fail('请重新修改规格库存');
}
foreach ($attrs as $attr) {
if (!isset($attr['unique']) || !isset($attr['pm']) || !isset($attr['stock'])) {
return $this->fail('请重新修改规格库存');
}
}
return $this->success(['stock' => $services->saveProductAttrsStock((int)$id, $attrs)]);
}
/**
* 导入卡密
* @return mixed
* @throws \PhpOffice\PhpSpreadsheet\Reader\Exception
*/
public function import_card()
{
$data = $this->request->getMore([
['file', ""]
]);
if (!$data['file']) return app('json')->fail('请上传文件');
$file = public_path() . substr($data['file'], 1);
/** @var FileService $readExcelService */
$readExcelService = app()->make(FileService::class);
$cardData = $readExcelService->readProductCardExcel($file, 2);
return app('json')->success($cardData);
}
/**
* 导入erp商品
* @return mixed
* @throws \PhpOffice\PhpSpreadsheet\Exception
* @throws \PhpOffice\PhpSpreadsheet\Reader\Exception
*/
public function import_erp_product()
{
[$path] = $this->request->postMore([
['path', ""]
], true);
if (!$path) {
return $this->fail('请上传表格');
}
$path = public_path() . substr($path, 1);
$data = SpreadsheetExcelService::getExcelData($path, ['spu' => 'A']);
$spus = [];
foreach ($data as $item) {
$spus[] = $item['spu'];
}
$spus = array_unique(array_filter($spus));
foreach ($spus as $spu) {
ProductSyncErp::dispatchDo('productFromErp', [$spu]);
}
unlink($path);
return $this->success('已加入消息队列进行同步');
}
/**
* 商品批量操作
* @param StoreProductBatchProcessServices $batchProcessServices
* @return mixed
*/
public function batchProcess(StoreProductBatchProcessServices $batchProcessServices)
{
[$type, $ids, $all, $where, $data] = $this->request->postMore([
['type', 1],
['ids', ''],
['all', 0],
['where', ""],
['data', []]
], true);
if (!$ids && $all == 0) return $this->fail('请选择批处理商品');
if (!$data) {
return $this->fail('请选择批处理数据');
}
if (isset($where['type'])) {
$where['status'] = $where['type'];
unset($where['type']);
}
//批量操作
$batchProcessServices->batchProcess((int)$type, $ids, $data, !!$all, $where);
return app('json')->success('已加入消息队列,请稍后查看');
}
}