+ConstrainPayPercentage

This commit is contained in:
gazebo
2019-12-04 18:17:44 +08:00
parent 4d3eb5d94c
commit 5cecffc501
3 changed files with 177 additions and 154 deletions

View File

@@ -15,6 +15,7 @@ import (
"git.rosy.net.cn/jx-callback/business/partner" "git.rosy.net.cn/jx-callback/business/partner"
"git.rosy.net.cn/baseapi/utils" "git.rosy.net.cn/baseapi/utils"
"git.rosy.net.cn/baseapi/utils/errlist"
"git.rosy.net.cn/jx-callback/business/auth2/authprovider/weixin" "git.rosy.net.cn/jx-callback/business/auth2/authprovider/weixin"
"git.rosy.net.cn/jx-callback/business/jxutils" "git.rosy.net.cn/jx-callback/business/jxutils"
"git.rosy.net.cn/jx-callback/business/jxutils/jxcontext" "git.rosy.net.cn/jx-callback/business/jxutils/jxcontext"
@@ -959,9 +960,7 @@ func updateStoresSkusWithoutSync(ctx *jxcontext.Context, db *dao.DaoDB, storeIDs
} }
scaleFactor := float64(1) scaleFactor := float64(1)
if isScale { if isScale {
if storeDetail.PayPercentage > 0 { scaleFactor = float64(jxutils.ConstrainPayPercentage(storeDetail.PayPercentage) / 100)
scaleFactor = float64(storeDetail.PayPercentage) / 100
}
} }
for _, skuBindInfo := range skuBindInfos { for _, skuBindInfo := range skuBindInfos {
// 关注且没有给价时需要尝试从store_sku_bind中得到已有的单价 // 关注且没有给价时需要尝试从store_sku_bind中得到已有的单价
@@ -1270,7 +1269,7 @@ func UpdateStoresSkusSale(ctx *jxcontext.Context, storeIDs []int, skuBindSkuInfo
return hint, err return hint, err
} }
func CopyStoreSkus(ctx *jxcontext.Context, fromStoreID, toStoreID int, copyMode string, isScale bool, params map[string]interface{}, userName string) (num int64, err error) { func CopyStoreSkus(ctx *jxcontext.Context, fromStoreID int, toStoreIDs []int, copyMode string, isScale bool, params map[string]interface{}, userName string) (num int64, err error) {
if copyMode != CopyStoreSkuModeFresh && copyMode != CopyStoreSkuModeUpdate && copyMode != CopyStoreSkuModeUpdatePrice { if copyMode != CopyStoreSkuModeFresh && copyMode != CopyStoreSkuModeUpdate && copyMode != CopyStoreSkuModeUpdatePrice {
return 0, fmt.Errorf("不支持的拷贝模式:%s", copyMode) return 0, fmt.Errorf("不支持的拷贝模式:%s", copyMode)
} }
@@ -1280,11 +1279,6 @@ func CopyStoreSkus(ctx *jxcontext.Context, fromStoreID, toStoreID int, copyMode
if err != nil { if err != nil {
return 0, err return 0, err
} }
toStore, err := checkStoreExisting(db, toStoreID)
if err != nil {
return 0, err
}
sqlCatAndSku := "" sqlCatAndSku := ""
sqlCatAndSkuParams := make([]interface{}, 0) sqlCatAndSkuParams := make([]interface{}, 0)
if params["categoryIDs"] != nil { if params["categoryIDs"] != nil {
@@ -1311,10 +1305,16 @@ func CopyStoreSkus(ctx *jxcontext.Context, fromStoreID, toStoreID int, copyMode
if params["pricePercentage"] != nil { if params["pricePercentage"] != nil {
pricePercentage = params["pricePercentage"].(int) pricePercentage = params["pricePercentage"].(int)
} }
errList := errlist.New()
now := time.Now() for _, toStoreID := range toStoreIDs {
if fromStoreID == toStoreID { toStore, err := checkStoreExisting(db, toStoreID)
sql := ` if err != nil {
errList.AddErr(err)
break
}
now := time.Now()
if fromStoreID == toStoreID {
sql := `
UPDATE store_sku_bind t1 UPDATE store_sku_bind t1
JOIN sku t2 ON t1.sku_id = t2.id AND t2.deleted_at = ? JOIN sku t2 ON t1.sku_id = t2.id AND t2.deleted_at = ?
JOIN sku_name t3 ON t2.name_id = t3.id AND t2.deleted_at = ? JOIN sku_name t3 ON t2.name_id = t3.id AND t2.deleted_at = ?
@@ -1329,36 +1329,41 @@ func CopyStoreSkus(ctx *jxcontext.Context, fromStoreID, toStoreID int, copyMode
t1.ebai_sync_status = t1.ebai_sync_status | ? t1.ebai_sync_status = t1.ebai_sync_status | ?
WHERE t1.store_id = ? AND t1.deleted_at = ? WHERE t1.store_id = ? AND t1.deleted_at = ?
` `
sqlParams := []interface{}{ sqlParams := []interface{}{
utils.DefaultTimeValue, utils.DefaultTimeValue,
utils.DefaultTimeValue, utils.DefaultTimeValue,
utils.DefaultTimeValue, utils.DefaultTimeValue,
userName, userName,
now, now,
pricePercentage, pricePercentage,
pricePercentage, pricePercentage,
pricePercentage, pricePercentage,
model.SyncFlagPriceMask, model.SyncFlagPriceMask,
model.SyncFlagPriceMask, model.SyncFlagPriceMask,
model.SyncFlagPriceMask, model.SyncFlagPriceMask,
toStoreID, toStoreID,
utils.DefaultTimeValue, utils.DefaultTimeValue,
}
sql += sqlCatAndSku
sqlParams = append(sqlParams, sqlCatAndSkuParams)
num2, err2 := dao.ExecuteSQL(db, sql, sqlParams)
if err2 != nil {
errList.AddErr(err2)
} else {
num += num2
}
break
} }
sql += sqlCatAndSku dao.Begin(db)
sqlParams = append(sqlParams, sqlCatAndSkuParams) defer func() {
num, err = dao.ExecuteSQL(db, sql, sqlParams) if r := recover(); r != nil {
return num, err dao.Rollback(db)
} panic(r)
dao.Begin(db) }
defer func() { }()
dao.Rollback(db) if copyMode == CopyStoreSkuModeFresh {
if r := recover(); r != nil { // 将toStore中存在但fromStore中不存在的置删除标志
panic(r) sqlDelete := `
}
}()
if copyMode == CopyStoreSkuModeFresh {
// 将toStore中存在但fromStore中不存在的置删除标志
sqlDelete := `
UPDATE store_sku_bind t1 UPDATE store_sku_bind t1
LEFT JOIN store_sku_bind t0 ON t0.store_id = ? AND t0.sku_id = t1.sku_id AND t0.deleted_at = ? LEFT JOIN store_sku_bind t0 ON t0.store_id = ? AND t0.sku_id = t1.sku_id AND t0.deleted_at = ?
JOIN sku t2 ON t1.sku_id = t2.id/* AND t2.deleted_at = ?*/ JOIN sku t2 ON t1.sku_id = t2.id/* AND t2.deleted_at = ?*/
@@ -1374,53 +1379,51 @@ func CopyStoreSkus(ctx *jxcontext.Context, fromStoreID, toStoreID int, copyMode
t1.ebai_sync_status = IF((t1.ebai_sync_status & ?) <> 0, 0, ?) t1.ebai_sync_status = IF((t1.ebai_sync_status & ?) <> 0, 0, ?)
WHERE t1.store_id = ? AND t1.deleted_at = ? AND t0.id IS NULL WHERE t1.store_id = ? AND t1.deleted_at = ? AND t0.id IS NULL
` `
sqlDeleteParams := []interface{}{ sqlDeleteParams := []interface{}{
fromStoreID, fromStoreID,
utils.DefaultTimeValue, utils.DefaultTimeValue,
// utils.DefaultTimeValue, // utils.DefaultTimeValue,
// utils.DefaultTimeValue, // utils.DefaultTimeValue,
utils.DefaultTimeValue, utils.DefaultTimeValue,
now, now,
now, now,
userName, userName,
model.StoreSkuBindStatusDeleted, model.StoreSkuBindStatusDeleted,
model.SyncFlagNewMask, model.SyncFlagNewMask,
model.SyncFlagDeletedMask, model.SyncFlagDeletedMask,
model.SyncFlagNewMask, model.SyncFlagNewMask,
model.SyncFlagDeletedMask, model.SyncFlagDeletedMask,
model.SyncFlagNewMask, model.SyncFlagNewMask,
model.SyncFlagDeletedMask, model.SyncFlagDeletedMask,
toStoreID, toStoreID,
utils.DefaultTimeValue, utils.DefaultTimeValue,
}
sqlDelete += sqlCatAndSku
sqlDeleteParams = append(sqlDeleteParams, sqlCatAndSkuParams)
// globals.SugarLogger.Debug(sqlDelete)
num2, err2 := dao.ExecuteSQL(db, sqlDelete, sqlDeleteParams)
if err = err2; err != nil {
errList.AddErr(err)
dao.Rollback(db)
break
}
num += num2
globals.SugarLogger.Debugf("CopyStoreSkus fromStoreID:%d, toStoreID:%d, trackInfo:%s num1:%d", fromStoreID, toStoreID, ctx.GetTrackInfo(), num2)
} }
sqlDelete += sqlCatAndSku isModifyStatus := 1
sqlDeleteParams = append(sqlDeleteParams, sqlCatAndSkuParams) syncStatus := model.SyncFlagStoreSkuOnlyMask
// globals.SugarLogger.Debug(sqlDelete) if copyMode == CopyStoreSkuModeUpdatePrice {
if num, err = dao.ExecuteSQL(db, sqlDelete, sqlDeleteParams); err != nil { isModifyStatus = 0
return 0, err syncStatus = model.SyncFlagPriceMask
} }
globals.SugarLogger.Debugf("CopyStoreSkus trackInfo:%s num1:%d", ctx.GetTrackInfo(), num) scaleFactor := float64(1)
} if isScale {
isModifyStatus := 1 fromPayPercentage := jxutils.ConstrainPayPercentage(fromStore.PayPercentage)
syncStatus := model.SyncFlagStoreSkuOnlyMask toPayPercentage := jxutils.ConstrainPayPercentage(toStore.PayPercentage)
if copyMode == CopyStoreSkuModeUpdatePrice { scaleFactor = float64(fromPayPercentage) / float64(toPayPercentage)
isModifyStatus = 0
syncStatus = model.SyncFlagPriceMask
}
scaleFactor := float64(1)
if isScale {
fromPayPercentage := fromStore.PayPercentage
if fromPayPercentage <= 0 {
fromPayPercentage = 100
} }
toPayPercentage := toStore.PayPercentage // 处理toStore中与fromStore中都存在的
if toPayPercentage <= 0 { sql := `
toPayPercentage = 100
}
scaleFactor = float64(fromPayPercentage) / float64(toPayPercentage)
}
// 处理toStore中与fromStore中都存在的
sql := `
UPDATE store_sku_bind t1 UPDATE store_sku_bind t1
JOIN store t11 ON t11.id = t1.store_id JOIN store t11 ON t11.id = t1.store_id
LEFT JOIN store_sku_bind t0 ON t0.store_id = ? AND t0.sku_id = t1.sku_id AND t0.deleted_at = ? LEFT JOIN store_sku_bind t0 ON t0.store_id = ? AND t0.sku_id = t1.sku_id AND t0.deleted_at = ?
@@ -1441,41 +1444,43 @@ func CopyStoreSkus(ctx *jxcontext.Context, fromStoreID, toStoreID int, copyMode
t1.ebai_sync_status = t1.ebai_sync_status | ? t1.ebai_sync_status = t1.ebai_sync_status | ?
WHERE t1.store_id = ? AND t1.deleted_at = ? AND t0.id IS NOT NULL WHERE t1.store_id = ? AND t1.deleted_at = ? AND t0.id IS NOT NULL
` `
sqlParams := []interface{}{ sqlParams := []interface{}{
fromStoreID, fromStoreID,
utils.DefaultTimeValue, utils.DefaultTimeValue,
// utils.DefaultTimeValue, // utils.DefaultTimeValue,
// utils.DefaultTimeValue, // utils.DefaultTimeValue,
utils.DefaultTimeValue, utils.DefaultTimeValue,
userName, userName,
now, now,
pricePercentage, pricePercentage,
pricePercentage, pricePercentage,
scaleFactor, scaleFactor,
pricePercentage, pricePercentage,
pricePercentage, pricePercentage,
scaleFactor, scaleFactor,
pricePercentage, pricePercentage,
pricePercentage, pricePercentage,
scaleFactor, scaleFactor,
isModifyStatus, isModifyStatus,
syncStatus, syncStatus,
syncStatus, syncStatus,
syncStatus, syncStatus,
toStoreID, toStoreID,
utils.DefaultTimeValue, utils.DefaultTimeValue,
} }
sql += sqlCatAndSku sql += sqlCatAndSku
sqlParams = append(sqlParams, sqlCatAndSkuParams) sqlParams = append(sqlParams, sqlCatAndSkuParams)
// globals.SugarLogger.Debug(sql) // globals.SugarLogger.Debug(sql)
num, err = dao.ExecuteSQL(db, sql, sqlParams) num2, err2 := dao.ExecuteSQL(db, sql, sqlParams)
globals.SugarLogger.Debugf("CopyStoreSkus trackInfo:%s num2:%d", ctx.GetTrackInfo(), num) globals.SugarLogger.Debugf("CopyStoreSkus fromStoreID:%d, toStoreID:%d, trackInfo:%s num2:%d", fromStoreID, toStoreID, ctx.GetTrackInfo(), num2)
if err != nil { if err = err2; err != nil {
return 0, err errList.AddErr(err)
} dao.Rollback(db)
break
// 添加toStore中不存在但fromStore存在的 }
sql = ` num += num2
// 添加toStore中不存在但fromStore存在的
sql = `
INSERT INTO store_sku_bind(created_at, updated_at, last_operator, deleted_at, store_id, sku_id, sub_store_id, price, jx_price, unit_price, status, INSERT INTO store_sku_bind(created_at, updated_at, last_operator, deleted_at, store_id, sku_id, sub_store_id, price, jx_price, unit_price, status,
jd_sync_status, ebai_sync_status, mtwm_sync_status) jd_sync_status, ebai_sync_status, mtwm_sync_status)
SELECT ?, ?, ?, ?, ?, SELECT ?, ?, ?, ?, ?,
@@ -1491,39 +1496,43 @@ func CopyStoreSkus(ctx *jxcontext.Context, fromStoreID, toStoreID int, copyMode
LEFT JOIN store_sku_bind t0 ON t1.sku_id = t0.sku_id AND t0.store_id = ? AND t0.deleted_at = ? LEFT JOIN store_sku_bind t0 ON t1.sku_id = t0.sku_id AND t0.store_id = ? AND t0.deleted_at = ?
WHERE t1.store_id = ? AND t1.deleted_at = ? WHERE t1.store_id = ? AND t1.deleted_at = ?
` `
sqlParams = []interface{}{ sqlParams = []interface{}{
now, now, userName, utils.DefaultTimeValue, toStoreID, now, now, userName, utils.DefaultTimeValue, toStoreID,
pricePercentage, pricePercentage,
pricePercentage, pricePercentage,
scaleFactor, scaleFactor,
pricePercentage, pricePercentage,
pricePercentage, pricePercentage,
scaleFactor, scaleFactor,
pricePercentage, pricePercentage,
pricePercentage, pricePercentage,
scaleFactor, scaleFactor,
isModifyStatus, isModifyStatus,
model.SkuStatusDontSale, model.SkuStatusDontSale,
model.SyncFlagNewMask, model.SyncFlagNewMask,
model.SyncFlagNewMask, model.SyncFlagNewMask,
model.SyncFlagNewMask, model.SyncFlagNewMask,
utils.DefaultTimeValue, utils.DefaultTimeValue,
utils.DefaultTimeValue, utils.DefaultTimeValue,
utils.DefaultTimeValue, utils.DefaultTimeValue,
toStoreID, toStoreID,
utils.DefaultTimeValue, utils.DefaultTimeValue,
fromStoreID, fromStoreID,
utils.DefaultTimeValue, utils.DefaultTimeValue,
}
sql += sqlCatAndSku + " AND t0.id IS NULL"
sqlParams = append(sqlParams, sqlCatAndSkuParams)
num2, err = dao.ExecuteSQL(db, sql, sqlParams)
if err != nil {
errList.AddErr(err)
dao.Rollback(db)
break
}
num += num2
globals.SugarLogger.Debugf("CopyStoreSkus fromStoreID:%d, toStoreID:%d, trackInfo:%s num3:%d", fromStoreID, toStoreID, ctx.GetTrackInfo(), num2)
dao.Commit(db)
} }
sql += sqlCatAndSku + " AND t0.id IS NULL" return num, errList.GetErrListAsOne()
sqlParams = append(sqlParams, sqlCatAndSkuParams)
num, err = dao.ExecuteSQL(db, sql, sqlParams)
if err != nil {
return 0, err
}
globals.SugarLogger.Debugf("CopyStoreSkus trackInfo:%s num3:%d", ctx.GetTrackInfo(), num)
dao.Commit(db)
return num, err
} }
func shouldPendingStorePriceChange(ctx *jxcontext.Context, storeID int, skuBindInfo *StoreSkuBindInfo) (shouldPending bool, err error) { func shouldPendingStorePriceChange(ctx *jxcontext.Context, storeID int, skuBindInfo *StoreSkuBindInfo) (shouldPending bool, err error) {

View File

@@ -326,6 +326,13 @@ func CaculatePriceByPricePack(l model.PricePercentagePack, defPricePercentage, p
return CaculateSkuVendorPrice(price, pricePercentage, priceAdd) return CaculateSkuVendorPrice(price, pricePercentage, priceAdd)
} }
func ConstrainPayPercentage(payPerCentage int) int {
if payPerCentage <= 50 {
payPerCentage = 70
}
return payPerCentage
}
func IsSkuSpecial(specQuality float32, specUnit string) bool { func IsSkuSpecial(specQuality float32, specUnit string) bool {
return int(specQuality) == model.SpecialSpecQuality && (specUnit == model.SpecialSpecUnit || specUnit == model.SpecialSpecUnit2) return int(specQuality) == model.SpecialSpecQuality && (specUnit == model.SpecialSpecUnit || specUnit == model.SpecialSpecUnit2)
} }

View File

@@ -249,6 +249,7 @@ func (c *StoreSkuController) UpdateStoresSkusByBind() {
// @Param token header string true "认证token" // @Param token header string true "认证token"
// @Param fromStoreID formData int true "源门店ID" // @Param fromStoreID formData int true "源门店ID"
// @Param toStoreID formData int true "目标门店ID" // @Param toStoreID formData int true "目标门店ID"
// @Param toStoreIDs formData string false "目标门店ID列表"
// @Param copyMode formData string true "拷贝模式fresh:目标门店数据全部清除后拷贝update:确保指定的源数据全部拷贝,已有的忽略" // @Param copyMode formData string true "拷贝模式fresh:目标门店数据全部清除后拷贝update:确保指定的源数据全部拷贝,已有的忽略"
// @Param pricePercentage formData int false "价格调整百分比缺省为100%" // @Param pricePercentage formData int false "价格调整百分比缺省为100%"
// @Param categoryIDs formData string false "json数据skuName所属的类别[1,2,3]" // @Param categoryIDs formData string false "json数据skuName所属的类别[1,2,3]"
@@ -259,7 +260,13 @@ func (c *StoreSkuController) UpdateStoresSkusByBind() {
// @router /CopyStoreSkus [post] // @router /CopyStoreSkus [post]
func (c *StoreSkuController) CopyStoreSkus() { func (c *StoreSkuController) CopyStoreSkus() {
c.callCopyStoreSkus(func(params *tStoreSkuCopyStoreSkusParams) (retVal interface{}, errCode string, err error) { c.callCopyStoreSkus(func(params *tStoreSkuCopyStoreSkusParams) (retVal interface{}, errCode string, err error) {
retVal, err = cms.CopyStoreSkus(params.Ctx, params.FromStoreID, params.ToStoreID, params.CopyMode, params.IsScale, params.MapData, params.Ctx.GetUserName()) var toStoreIDs []int
if err = jxutils.Strings2Objs(params.ToStoreIDs, &toStoreIDs); err == nil {
if params.ToStoreID > 0 {
toStoreIDs = append(toStoreIDs, params.ToStoreID)
}
retVal, err = cms.CopyStoreSkus(params.Ctx, params.FromStoreID, toStoreIDs, params.CopyMode, params.IsScale, params.MapData, params.Ctx.GetUserName())
}
return retVal, "", err return retVal, "", err
}) })
} }