- 移除partner.GetStoresSku
This commit is contained in:
@@ -1983,84 +1983,109 @@ func RefreshStoresSkuByVendor(ctx *jxcontext.Context, storeIDs []int, vendorID i
|
||||
return "", err
|
||||
}
|
||||
}
|
||||
|
||||
handler := partner.GetPurchasePlatformFromVendorID(vendorID)
|
||||
var storeSkuList []*model.StoreSkuBind
|
||||
rootTask := tasksch.NewSeqTask(fmt.Sprintf("根据厂家门店商品信息相应刷新本地数据:%v", storeIDs), ctx,
|
||||
func(task *tasksch.SeqTask, step int, params ...interface{}) (result interface{}, err error) {
|
||||
switch step {
|
||||
case 0:
|
||||
storeSkuList, err = handler.GetStoresSku(ctx, task, storeIDs)
|
||||
case 1:
|
||||
if len(storeSkuList) > 0 {
|
||||
var skuList []*model.SkuAndName
|
||||
skuList, err = dao.GetSkus(db, nil, nil, nil, nil)
|
||||
if err == nil {
|
||||
skuNameMap := make(map[int]*model.SkuName)
|
||||
skuMap := make(map[int]*model.SkuAndName)
|
||||
for _, sku := range skuList {
|
||||
if skuNameMap[sku.NameID] == nil {
|
||||
skuNameMap[sku.NameID] = &model.SkuName{
|
||||
Unit: sku.Unit,
|
||||
}
|
||||
}
|
||||
skuMap[sku.ID] = sku
|
||||
}
|
||||
for _, v := range storeSkuList {
|
||||
sku := skuMap[v.SkuID]
|
||||
skuName := skuNameMap[sku.NameID]
|
||||
if skuName.IsGlobal == 0 && (jxutils.IsSkuSpecial(sku.SpecQuality, sku.SpecUnit) || skuName.Unit != model.SpecialUnit) {
|
||||
skuName.Price = v.Price
|
||||
skuName.IsGlobal = 1 // 标准价
|
||||
}
|
||||
}
|
||||
for _, v := range storeSkuList {
|
||||
sku := skuMap[v.SkuID]
|
||||
skuName := skuNameMap[sku.NameID]
|
||||
if skuName.IsGlobal == 0 {
|
||||
if skuName.Price == 0 {
|
||||
skuName.Price = jxutils.CaculateUnitPrice(v.Price, sku.SpecQuality, sku.SpecUnit, skuName.Unit)
|
||||
} else {
|
||||
skuName.Price = (skuName.Price + jxutils.CaculateUnitPrice(v.Price, sku.SpecQuality, sku.SpecUnit, skuName.Unit)) / 2
|
||||
}
|
||||
}
|
||||
}
|
||||
for _, v := range storeSkuList {
|
||||
pricePercentage := jxutils.GetPricePercentageByVendorPrice(storeMap[v.StoreID].PricePercentagePackObj, v.UnitPrice, int(storeMap[v.StoreID].PricePercentage))
|
||||
skuName := skuNameMap[skuMap[v.SkuID].NameID]
|
||||
v.Price = jxutils.CaculateSkuPriceFromVendor(v.Price, pricePercentage, 0)
|
||||
v.UnitPrice = jxutils.CaculateSkuPriceFromVendor(skuName.Price, pricePercentage, 0)
|
||||
dao.WrapAddIDCULDEntity(v, ctx.GetUserName())
|
||||
setStoreSkuBindStatus(v, model.SyncFlagNewMask)
|
||||
v.JdSyncStatus = 0
|
||||
}
|
||||
}
|
||||
}
|
||||
case 2:
|
||||
if len(storeSkuList) > 0 {
|
||||
dao.Begin(db)
|
||||
defer func() {
|
||||
if r := recover(); r != nil || err != nil {
|
||||
dao.Rollback(db)
|
||||
if r != nil {
|
||||
panic(r)
|
||||
}
|
||||
}
|
||||
}()
|
||||
if _, err = dao.ExecuteSQL(db, `
|
||||
DELETE t1
|
||||
FROM store_sku_bind t1
|
||||
WHERE t1.store_id IN (
|
||||
`+dao.GenQuestionMarks(len(storeIDs))+")", storeIDs); err == nil {
|
||||
if err = dao.CreateMultiEntities(db, storeSkuList); err == nil {
|
||||
hint = utils.Int2Str(len(storeSkuList))
|
||||
dao.Commit(db)
|
||||
}
|
||||
}
|
||||
}
|
||||
skuList, err := dao.GetSkus(db, nil, nil, nil, nil)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
skuNameMap := make(map[int]*model.SkuName)
|
||||
skuMap := make(map[int]*model.SkuAndName)
|
||||
var bareStoreSkuList []*partner.StoreSkuInfo
|
||||
for _, sku := range skuList {
|
||||
if skuNameMap[sku.NameID] == nil {
|
||||
skuNameMap[sku.NameID] = &model.SkuName{
|
||||
Unit: sku.Unit,
|
||||
}
|
||||
return nil, err
|
||||
}, 3)
|
||||
}
|
||||
skuMap[sku.ID] = sku
|
||||
|
||||
bareStoreSkuList = append(bareStoreSkuList, &partner.StoreSkuInfo{
|
||||
SkuID: sku.ID,
|
||||
VendorSkuID: utils.Int64ToStr(sku.JdID),
|
||||
})
|
||||
}
|
||||
|
||||
handler := partner.GetPurchasePlatformFromVendorID(vendorID).(partner.IPurchasePlatformStoreSkuHandler)
|
||||
var storeSkuList []*model.StoreSkuBind
|
||||
rootTask := tasksch.NewParallelTask(fmt.Sprintf("根据厂家门店商品信息相应刷新本地数据:%v", storeIDs), tasksch.NewParallelConfig().SetParallelCount(1), ctx,
|
||||
func(task *tasksch.ParallelTask, batchItemList []interface{}, params ...interface{}) (retVal interface{}, err error) {
|
||||
oneStoreMap := batchItemList[0].(*model.StoreMap)
|
||||
subTask := tasksch.NewSeqTask(fmt.Sprintf("根据厂家门店商品信息相应刷新本地数据:%s", model.VendorChineseNames[oneStoreMap.VendorID]), ctx,
|
||||
func(task *tasksch.SeqTask, step int, params ...interface{}) (result interface{}, err error) {
|
||||
switch step {
|
||||
case 0:
|
||||
bareStoreSkuList, err2 := handler.GetStoreSkusBareInfo(ctx, task, oneStoreMap.StoreID, oneStoreMap.VendorStoreID, bareStoreSkuList)
|
||||
// globals.SugarLogger.Debug(utils.Format4Output(bareStoreSkuList, false))
|
||||
if err = err2; err == nil || len(bareStoreSkuList) > 0 {
|
||||
err = nil // todo 如果部分失败,强制忽略错误
|
||||
for _, v := range bareStoreSkuList {
|
||||
storeSkuList = append(storeSkuList, &model.StoreSkuBind{
|
||||
StoreID: oneStoreMap.StoreID,
|
||||
SkuID: v.SkuID,
|
||||
Status: v.Status,
|
||||
Price: int(v.VendorPrice),
|
||||
})
|
||||
}
|
||||
}
|
||||
case 1:
|
||||
if len(storeSkuList) > 0 {
|
||||
for _, v := range storeSkuList {
|
||||
sku := skuMap[v.SkuID]
|
||||
skuName := skuNameMap[sku.NameID]
|
||||
if skuName.IsGlobal == 0 && (jxutils.IsSkuSpecial(sku.SpecQuality, sku.SpecUnit) || skuName.Unit != model.SpecialUnit) {
|
||||
skuName.Price = v.Price // 标准价
|
||||
skuName.IsGlobal = 1
|
||||
}
|
||||
}
|
||||
for _, v := range storeSkuList {
|
||||
sku := skuMap[v.SkuID]
|
||||
skuName := skuNameMap[sku.NameID]
|
||||
if skuName.IsGlobal == 0 {
|
||||
if skuName.Price == 0 {
|
||||
skuName.Price = jxutils.CaculateUnitPrice(v.Price, sku.SpecQuality, sku.SpecUnit, skuName.Unit)
|
||||
} else {
|
||||
skuName.Price = (skuName.Price + jxutils.CaculateUnitPrice(v.Price, sku.SpecQuality, sku.SpecUnit, skuName.Unit)) / 2
|
||||
}
|
||||
}
|
||||
}
|
||||
for _, v := range storeSkuList {
|
||||
pricePercentage := jxutils.GetPricePercentageByVendorPrice(storeMap[v.StoreID].PricePercentagePackObj, v.UnitPrice, int(storeMap[v.StoreID].PricePercentage))
|
||||
skuName := skuNameMap[skuMap[v.SkuID].NameID]
|
||||
v.Price = jxutils.CaculateSkuPriceFromVendor(v.Price, pricePercentage, 0)
|
||||
v.UnitPrice = jxutils.CaculateSkuPriceFromVendor(skuName.Price, pricePercentage, 0)
|
||||
dao.WrapAddIDCULDEntity(v, ctx.GetUserName())
|
||||
setStoreSkuBindStatus(v, model.SyncFlagNewMask)
|
||||
v.JdSyncStatus = 0
|
||||
}
|
||||
}
|
||||
case 2:
|
||||
if len(storeSkuList) > 0 {
|
||||
dao.Begin(db)
|
||||
defer func() {
|
||||
if r := recover(); r != nil || err != nil {
|
||||
dao.Rollback(db)
|
||||
if r != nil {
|
||||
panic(r)
|
||||
}
|
||||
}
|
||||
}()
|
||||
if _, err = dao.ExecuteSQL(db, `
|
||||
DELETE t1
|
||||
FROM store_sku_bind t1
|
||||
WHERE t1.store_id IN (
|
||||
`+dao.GenQuestionMarks(len(storeIDs))+")", storeIDs); err == nil {
|
||||
if err = dao.CreateMultiEntities(db, storeSkuList); err == nil {
|
||||
hint = utils.Int2Str(len(storeSkuList))
|
||||
dao.Commit(db)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return nil, err
|
||||
}, 3)
|
||||
tasksch.HandleTask(subTask, task, true).Run()
|
||||
_, err = subTask.GetResult(0)
|
||||
return retVal, err
|
||||
}, storeMapList)
|
||||
tasksch.ManageTask(rootTask).Run()
|
||||
if isAsync {
|
||||
hint = rootTask.GetID()
|
||||
|
||||
Reference in New Issue
Block a user