定时修改商品可售状态

This commit is contained in:
苏尹岚
2019-11-14 11:45:16 +08:00
parent 32eb1a6dbe
commit e15e7ed9e2
4 changed files with 93 additions and 1 deletions

View File

@@ -3,6 +3,7 @@ package cms
import (
"errors"
"fmt"
"time"
"git.rosy.net.cn/baseapi/utils"
"git.rosy.net.cn/jx-callback/business/jxutils"
@@ -653,3 +654,32 @@ func (v *VendorSync) SyncSkuNames(ctx *jxcontext.Context, nameIDs []int, isForce
}
return v.SyncSkus(ctx, db, nameIDs, nil, isAsync, isContinueWhenError, ctx.GetUserName())
}
func (v *VendorSync) ChangeStoreSkuSaleStatus(ctx *jxcontext.Context, isAsync, isContinueWhenError bool) (err error) {
var (
storeIDs []int
skuIDs []int
vendorIDs = []int{0, 1, 3}
)
db := dao.GetDB()
now := time.Now().Hour()*100 + time.Now().Minute()
storeSkuList, err := dao.GetStoresSkusInfoBySaleTime(db)
for _, v := range storeSkuList {
if (now >= v.TimeBegin1 && now <= v.TimeEnd1) || (now >= v.TimeBegin2 && now <= v.TimeEnd2) {
skuIDs = append(skuIDs, v.StoreSkuBind.SkuID)
storeIDs = append(storeIDs, v.StoreSkuBind.StoreID)
v.StoreSkuBind.Status = model.SkuStatusDontSale
setStoreSkuBindStatus(&v.StoreSkuBind, model.SyncFlagSaleMask)
dao.UpdateEntity(db, &v.StoreSkuBind)
} else {
v.StoreSkuBind.Status = model.SkuStatusNormal
setStoreSkuBindStatus(&v.StoreSkuBind, model.SyncFlagSaleMask)
dao.UpdateEntity(db, &v.StoreSkuBind)
}
}
v.SyncStoresSkus(ctx, db, vendorIDs, storeIDs, skuIDs, false, isAsync, isContinueWhenError)
if err != nil {
return err
}
return nil
}

View File

@@ -46,6 +46,32 @@ var (
"19:00:00",
"22:00:00",
}
ChangeStoreSkuSaleStatusList = []string{
"0:00:00",
"1:00:00",
"2:00:00",
"3:00:00",
"4:00:00",
"5:00:00",
"6:00:00",
"7:00:00",
"8:00:00",
"9:00:00",
"10:00:00",
"11:00:00",
"12:00:00",
"13:00:00",
"14:00:00",
"15:00:00",
"16:00:00",
"17:00:00",
"18:00:00",
"19:00:00",
"20:00:00",
"21:00:00",
"22:00:00",
"23:00:00",
}
openRemoteStoreTimeList = []string{
"23:30:00",
}
@@ -117,6 +143,9 @@ func Init() {
}, []string{
"04:05:06",
})
ScheduleTimerFunc("ChangeStoreSkuSaleStatus", func() {
cms.CurVendorSync.ChangeStoreSkuSaleStatus(jxcontext.AdminCtx, false, false)
}, ChangeStoreSkuSaleStatusList)
}
}

View File

@@ -203,10 +203,16 @@ func LoadExcelByYongHui(ctx *jxcontext.Context, files []*multipart.FileHeader, i
}
taskSeq := tasksch.NewSeqTask("读取永辉Excel文件修改微盟商品价格可售状态-序列任务", ctx, taskSeqFunc, 4)
tasksch.HandleTask(taskSeq, nil, true).Run()
if !isAsync {
_, err = taskSeq.GetResult(0)
hint = "1"
} else {
hint = taskSeq.GetID()
}
if errMsg != "" {
baseapi.SugarLogger.Debugf(errMsg)
}
return "", err
return hint, err
}
func PutAwayWeiMobSku(goodsIDListForPutAway []int64) {

View File

@@ -107,6 +107,14 @@ type StoreSkuNameInfo struct {
UnitPrice int64
}
type StoreSkuBindWithSaleTime struct {
StoreSkuBind model.StoreSkuBind
TimeBegin1 int
TimeEnd1 int
TimeBegin2 int
TimeEnd2 int
}
// todo 应该通过需要同步的skuid来驱动同步分类而不是当前这种分开的逻辑
// 单门店模式厂商适用
// 从store_sku_bind中得到所有依赖的商家分类信息
@@ -584,3 +592,22 @@ func (s *StoreSkuSyncInfo) GetSeq() int {
}
return int(s.VendorPrice)
}
func GetStoresSkusInfoBySaleTime(db *DaoDB) (storeSkuBindList []*StoreSkuBindWithSaleTime, err error) {
sql := `
SELECT t1.*,
IF(t2.open_time1 <= t1.status_sale_begin,t2.open_time1,0) time_begin1,
IF(t2.open_time1 <= t1.status_sale_begin,t1.status_sale_begin,0) time_end1,
IF(t2.close_time1 >= t1.status_sale_end,t1.status_sale_end,0) time_begin2,
IF(t2.close_time1 >= t1.status_sale_end,t2.close_time1,0) time_end2
FROM store_sku_bind t1
JOIN store t2 ON t1.store_id = t2.id
WHERE t1.status_sale_begin <> 0 AND t1.status_sale_end <> 0
AND t1.status != ?
`
sqlParams := []interface{}{
model.SkuStatusDeleted,
}
err = GetRows(db, &storeSkuBindList, sql, sqlParams...)
return storeSkuBindList, err
}