|
|
@ -206,10 +206,18 @@ class Collector extends BaseService |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
public function updateGoods(string $url, array $form, int $storeId): bool |
|
|
|
public function updateGoods(string $url, array $form, int $storeId): bool |
|
|
|
{ |
|
|
|
{ |
|
|
|
|
|
|
|
$goods = GoodsModel::where('goods_id', $form['goods_id'])->find(); |
|
|
|
|
|
|
|
//商品不存在 |
|
|
|
|
|
|
|
if (!$goods || !$url) { |
|
|
|
|
|
|
|
return false; |
|
|
|
|
|
|
|
} |
|
|
|
try { |
|
|
|
try { |
|
|
|
|
|
|
|
|
|
|
|
// 采集第三方商品数据 |
|
|
|
// 采集第三方商品数据 |
|
|
|
$original = $this->collector($url, $storeId); |
|
|
|
$original = $this->collector($url, $storeId); |
|
|
|
|
|
|
|
// echo "<pre>"; |
|
|
|
|
|
|
|
// print_r($original); |
|
|
|
|
|
|
|
// exit(); |
|
|
|
|
|
|
|
|
|
|
|
if ($original['spec_type'] == 20) { |
|
|
|
if ($original['spec_type'] == 20) { |
|
|
|
$original['spec_type'] = 10; |
|
|
|
$original['spec_type'] = 10; |
|
|
@ -219,7 +227,7 @@ class Collector extends BaseService |
|
|
|
|
|
|
|
|
|
|
|
$original['goods_price'] = $goods_price; |
|
|
|
$original['goods_price'] = $goods_price; |
|
|
|
$original['line_price'] = $goods_price; |
|
|
|
$original['line_price'] = $goods_price; |
|
|
|
$original['data_type'] = 1; |
|
|
|
$original['data_type'] = 1;//苏宁的数据变成的人工数据了,不再使用苏宁接口更新数据 |
|
|
|
$original['link_other'] = $url; |
|
|
|
$original['link_other'] = $url; |
|
|
|
unset($original['specData']); |
|
|
|
unset($original['specData']); |
|
|
|
|
|
|
|
|
|
|
@ -241,30 +249,55 @@ class Collector extends BaseService |
|
|
|
|
|
|
|
|
|
|
|
$original['cost_price'] = $form['cost_price_min']; |
|
|
|
$original['cost_price'] = $form['cost_price_min']; |
|
|
|
$data['link_other'] = $url; |
|
|
|
$data['link_other'] = $url; |
|
|
|
//$data['goods_id'] = $form['goods_id']; |
|
|
|
|
|
|
|
$data['goods_no'] = $original['goods_sku_no']; |
|
|
|
$data['goods_no'] = $original['goods_sku_no']; |
|
|
|
$data['content'] = $original['content']; |
|
|
|
$data['content'] = $original['content']; |
|
|
|
|
|
|
|
|
|
|
|
//重新计算利润和利润率 |
|
|
|
//重新计算利润和利润率 |
|
|
|
$data['goods_price_min'] = $original['goods_price']; |
|
|
|
$data['goods_price_min'] = $original['goods_price']; |
|
|
|
|
|
|
|
$data['goods_price_max'] = $original['goods_price']; |
|
|
|
$data['line_price_min'] = $original['goods_price']; |
|
|
|
$data['line_price_min'] = $original['goods_price']; |
|
|
|
$data['line_price_min'] = $original['goods_price']; |
|
|
|
$data['line_price_max'] = $original['goods_price']; |
|
|
|
$data['profit'] = $original['goods_price'] - $original['cost_price']; |
|
|
|
$data['profit'] = $original['goods_price'] - $original['cost_price']; |
|
|
|
$profit_rate = (float)$original['goods_price'] > 0 ? ($original['goods_price'] - $original['cost_price']) / $original['goods_price'] : 0.00; |
|
|
|
$profit_rate = (float)$original['goods_price'] > 0 ? ($original['goods_price'] - $original['cost_price']) / $original['goods_price'] : 0.00; |
|
|
|
$profit_rate = $profit_rate > 0.0001 ? bcmul((string)$profit_rate, "100", 2) : 0.00; |
|
|
|
$profit_rate = $profit_rate > 0.0001 ? bcmul((string)$profit_rate, "100", 2) : 0.00; |
|
|
|
$data['profit_rate'] = $profit_rate; |
|
|
|
$data['profit_rate'] = $profit_rate; |
|
|
|
|
|
|
|
|
|
|
|
// echo "<pre>"; |
|
|
|
// echo "<pre>"; |
|
|
|
// print_r($data); |
|
|
|
// print_r($data); |
|
|
|
// exit(); |
|
|
|
// exit(); |
|
|
|
// 事务处理:添加商品 |
|
|
|
// 事务处理:添加商品 |
|
|
|
$model = new GoodsModel(); |
|
|
|
$model = new GoodsModel(); |
|
|
|
$model->transaction(function () use ($form, $data, $original) { |
|
|
|
|
|
|
|
|
|
|
|
$goodsSku = [ |
|
|
|
|
|
|
|
'goods_price' => $original['goods_price'], |
|
|
|
|
|
|
|
'goods_sku_no' => $original['goods_sku_no'], |
|
|
|
|
|
|
|
]; |
|
|
|
|
|
|
|
//新阙通信的数据 |
|
|
|
|
|
|
|
if ($goods->channel == "xqtx") { |
|
|
|
|
|
|
|
//goods |
|
|
|
|
|
|
|
$data['stock_total'] = $form['stock_total']; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//设置当前商品价格 |
|
|
|
|
|
|
|
$data['profit'] = $original['goods_price'] - $original['cost_price']; |
|
|
|
|
|
|
|
$profit_rate = (float)$original['goods_price'] > 0 ? ($original['goods_price'] - $original['cost_price']) / $original['goods_price'] : 0.00; |
|
|
|
|
|
|
|
$profit_rate = $profit_rate > 0.0001 ? bcmul((string)$profit_rate, "100", 2) : 0.00; |
|
|
|
|
|
|
|
$data['profit_rate'] = $profit_rate; |
|
|
|
|
|
|
|
unset($data['link_other']); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//sku |
|
|
|
|
|
|
|
$goodsSku['stock_num'] = $form['stock_total']; |
|
|
|
|
|
|
|
unset($goodsSku['goods_price']); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
// var_dump($data); |
|
|
|
|
|
|
|
// var_dump($goodsSku); |
|
|
|
|
|
|
|
// exit(); |
|
|
|
|
|
|
|
$model->transaction(function () use ($form, $data, $original, $goodsSku) { |
|
|
|
// 添加商品 |
|
|
|
// 添加商品 |
|
|
|
GoodsModel::where('goods_id', $form['goods_id'])->update($data); |
|
|
|
GoodsModel::where('goods_id', $form['goods_id'])->update($data); |
|
|
|
// 新增商品与图片关联 |
|
|
|
// 新增商品与图片关联 |
|
|
|
GoodsImageModel1::updates((int)$form['goods_id'], $original['imagesIds']); |
|
|
|
GoodsImageModel1::updates((int)$form['goods_id'], $original['imagesIds']); |
|
|
|
//更新sku信息 |
|
|
|
//更新sku信息 |
|
|
|
GoodsSkuModel::where('goods_id', $form['goods_id'])->update(['goods_price' => $original['goods_price'], 'goods_sku_no' => $original['goods_sku_no']]); |
|
|
|
GoodsSkuModel::where('goods_id', $form['goods_id'])->update($goodsSku); |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
return true; |
|
|
|
return true; |
|
|
@ -299,6 +332,9 @@ class Collector extends BaseService |
|
|
|
$itemId = $this->getItemId($url, $store); |
|
|
|
$itemId = $this->getItemId($url, $store); |
|
|
|
// 商城采集设置 |
|
|
|
// 商城采集设置 |
|
|
|
$config = SettingModel::getItem(SettingEnum::COLLECTOR, $storeId); |
|
|
|
$config = SettingModel::getItem(SettingEnum::COLLECTOR, $storeId); |
|
|
|
|
|
|
|
if (isset($config['config']['99api']['apiKey']) && !$config['config']['99api']['apiKey']) { |
|
|
|
|
|
|
|
$config['config']['99api']['apiKey'] = '9271DA7BF37C6F50BED49B7F0ADD49A2'; |
|
|
|
|
|
|
|
} |
|
|
|
// 请求API查询商品详情 |
|
|
|
// 请求API查询商品详情 |
|
|
|
$item = CollectorFacade::store($store) |
|
|
|
$item = CollectorFacade::store($store) |
|
|
|
->setOptions($config['config'][$config['provider']]) |
|
|
|
->setOptions($config['config'][$config['provider']]) |
|
|
@ -423,7 +459,6 @@ class Collector extends BaseService |
|
|
|
} elseif ($data['spec_type'] === GoodsSpecTypeEnum::SINGLE) { |
|
|
|
} elseif ($data['spec_type'] === GoodsSpecTypeEnum::SINGLE) { |
|
|
|
$data['goods_price_min'] = $data['goods_price_max'] = $original['goods_price']; |
|
|
|
$data['goods_price_min'] = $data['goods_price_max'] = $original['goods_price']; |
|
|
|
$data['line_price_min'] = $data['line_price_max'] = $original['goods_price']; |
|
|
|
$data['line_price_min'] = $data['line_price_max'] = $original['goods_price']; |
|
|
|
$data['line_price_min'] = $data['line_price_max'] = $original['goods_price']; |
|
|
|
|
|
|
|
$data['cost_price_min'] = $original['cost_price'] ?? 0.00; |
|
|
|
$data['cost_price_min'] = $original['cost_price'] ?? 0.00; |
|
|
|
$data['profit'] = (float)$original['goods_price'] - (float)$original['cost_price']; |
|
|
|
$data['profit'] = (float)$original['goods_price'] - (float)$original['cost_price']; |
|
|
|
$profit_rate = (float)$original['goods_price'] > 0 ? ((float)$original['goods_price'] - (float)$original['cost_price']) / (float)$original['goods_price'] : 0.00; |
|
|
|
$profit_rate = (float)$original['goods_price'] > 0 ? ((float)$original['goods_price'] - (float)$original['cost_price']) / (float)$original['goods_price'] : 0.00; |
|
|
|