From 1417143eafbdb1429d3f348f675ed2a903b99369 Mon Sep 17 00:00:00 2001 From: lewis <604446095@qq.com> Date: Wed, 19 Feb 2025 18:06:33 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E6=94=B9=E5=95=86=E5=93=81=E6=94=B9?= =?UTF-8?q?=E4=BB=B7=E7=9A=84=E9=94=99=E8=AF=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../StoreProductPriceLogic.php | 23 +++++++++++++++---- 1 file changed, 19 insertions(+), 4 deletions(-) diff --git a/app/admin/logic/store_product_price/StoreProductPriceLogic.php b/app/admin/logic/store_product_price/StoreProductPriceLogic.php index 47aa10ac1..931eb57e4 100644 --- a/app/admin/logic/store_product_price/StoreProductPriceLogic.php +++ b/app/admin/logic/store_product_price/StoreProductPriceLogic.php @@ -61,7 +61,7 @@ class StoreProductPriceLogic extends BaseLogic if ($find) { $changePurchase = false; if ($find['purchase_lv'] != $params['purchase_lv']) { - $params = self::updateProductPriceList($find['product_id'], StoreProductPriceList::PriceTypeSupply, $params['purchase_lv'], $params, 'purchase', $find['purchase_price']); + $params = self::updateProductPriceList2($find['product_id'], 'supply_rate', $params['purchase_lv'], $params, 'purchase', $find['purchase_price']); $changePurchase = true; } if ($changePurchase) { @@ -70,13 +70,13 @@ class StoreProductPriceLogic extends BaseLogic $params['price'] = bcmul($params['purchase'], $params['price_lv'], 2); } if ($find['cost_lv'] != $params['cost_lv']) { - $params = self::updateProductPriceList($find['product_id'], StoreProductPriceList::PriceTypeBusiness, $params['cost_lv'], $params, 'cost', $params['purchase']); + $params = self::updateProductPriceList2($find['product_id'], 'merchant_rate', $params['cost_lv'], $params, 'cost', $find['purchase']); } if ($find['vip_lv'] != $params['vip_lv']) { - $params = self::updateProductPriceList($find['product_id'], StoreProductPriceList::PriceTypeVip, $params['vip_lv'], $params, 'vip_price', $params['purchase']); + $params = self::updateProductPriceList2($find['product_id'], 'vip_rate', $params['vip_lv'], $params, 'vip_price', $find['purchase']); } if ($find['price_lv'] != $params['price_lv']) { - $params = self::updateProductPriceList($find['product_id'], StoreProductPriceList::PriceTypeRetail, $params['price_lv'], $params, 'price', $params['purchase']); + $params = self::updateProductPriceList2($find['product_id'], 'price_rate', $params['price_lv'], $params, 'price', $find['purchase']); } $find->save([ 'status' => 1, @@ -112,6 +112,21 @@ class StoreProductPriceLogic extends BaseLogic } } + public static function updateProductPriceList2($productId, $field, $rate, $params, $index, $basePrice) + { + $id = StoreProductPriceList::where('product_id', $productId)->value('id'); + if (empty($id)) { + StoreProductPriceList::create([ + 'product_id' => $productId, + $field => $rate * 100, + ]); + } else { + StoreProductPriceList::where('id', $id)->update([$field => $rate * 100]); + } + $params[$index] = bcmul($basePrice, $rate, 2); + return $params; + } + public static function updateProductPriceList($productId, $priceType, $rate, $params, $field, $basePrice) { $id = StoreProductPriceList::where('product_id', $productId)->where('price_type', $priceType)->value('id');