Browse Source

fix:bug

dev
Tooooommy 4 years ago
parent
commit
7117d51860
  1. 11
      controllers/client/good.go
  2. 18
      controllers/client/order_entry.go

11
controllers/client/good.go

@ -184,12 +184,14 @@ func (t *GoodCtl) Order() {
for _, g := range param.Goods { for _, g := range param.Goods {
goodIds = append(goodIds, g["id"]) goodIds = append(goodIds, g["id"])
} }
goods := make([]*models.CustomerGoods, 0) goods := make([]*models.CustomerGoods, 0)
err = s.Where("is_delete=0").In("id", goodIds).Find(&goods) err = s.Where("is_delete=0").In("id", goodIds).Find(&goods)
if err != nil || len(goods) != len(goodIds) || len(goods) <= 0 { if err != nil || len(goods) != len(goodIds) || len(goods) <= 0 {
s.Rollback() s.Rollback()
t.ERROR("商品信息异常", code.MSG_DATA_NOT_EXIST) t.ERROR("商品信息异常", code.MSG_DATA_NOT_EXIST)
} }
orderGoodNum, err := models.GetSubOrderGoodNumBySession(s, goodIds) orderGoodNum, err := models.GetSubOrderGoodNumBySession(s, goodIds)
if err != nil { if err != nil {
s.Rollback() s.Rollback()
@ -201,15 +203,16 @@ func (t *GoodCtl) Order() {
var price = 0 var price = 0
// 检测库存 // 检测库存
for _, good := range goods { for _, good := range goods {
for _, g := range param.Goods {
if good.Id == g["id"] {
if good.Stock > -1 {
for _, v := range orderGoodNum { // 库存计算 for _, v := range orderGoodNum { // 库存计算
if v.GoodsId == good.Id { if v.GoodsId == good.Id {
good.Stock -= v.GoodsNum good.Stock -= v.GoodsNum
} }
} }
if good.Stock-g["num"] < 0 {
}
for _, g := range param.Goods {
if good.Id == g["id"] {
if good.Stock != -1 && good.Stock-g["num"] < 0 {
s.Rollback() s.Rollback()
t.ERROR("商品库存不足", code.MSG_DATA_NOT_EXIST) t.ERROR("商品库存不足", code.MSG_DATA_NOT_EXIST)
} else { } else {

18
controllers/client/order_entry.go

@ -60,12 +60,14 @@ func (t *OrderEntryCtl) List() {
qrcode, err := utils.Qrcode2Base64(url) qrcode, err := utils.Qrcode2Base64(url)
t.CheckErr(err) t.CheckErr(err)
goods[index].Qrcode = qrcode goods[index].Qrcode = qrcode
if goods[index].Stock == -1 {
for _, v := range res { for _, v := range res {
if goods[index].Id == v.GoodsId { if goods[index].Id == v.GoodsId {
goods[index].Stock -= v.GoodsNum goods[index].Stock -= v.GoodsNum
} }
} }
} }
}
t.JSON(map[string]interface{}{ t.JSON(map[string]interface{}{
"list": goods, "list": goods,
@ -129,6 +131,8 @@ func (t *OrderEntryCtl) Order() {
t.ERROR("商品信息异常", code.MSG_ERR_Param) t.ERROR("商品信息异常", code.MSG_ERR_Param)
return return
} }
if good.Stock > -1 { // 库存
// 找出商品库存 // 找出商品库存
ms, err := models.GetSubOrderGoodNumBySession(s, good.Id) ms, err := models.GetSubOrderGoodNumBySession(s, good.Id)
if err != nil { if err != nil {
@ -143,6 +147,7 @@ func (t *OrderEntryCtl) Order() {
} }
} }
}
order := models.CustomerOrder{} order := models.CustomerOrder{}
// 查询库存 // 查询库存
total, err := s.Where("is_delete=0").Count(&order) // 订单总数 total, err := s.Where("is_delete=0").Count(&order) // 订单总数
@ -342,11 +347,12 @@ func (t *OrderEntryCtl) ManualOrder() {
} }
} }
ms := make([]map[string]int, 0)
err = s.Table(&models.CustomerOrderSub{}).Alias("s").Select("s.goods_id, COALESCE(SUM(s.goods_num), 0) as goods_num").
Join("left", (&models.CustomerOrder{}).Alias("o"), "o.id=s.order_id").
Where("o.activity_id=? and o.rehearsal_id=? and o.arch_id=?", activity.Id, activity.RehearsalId, activity.ArchId).
In("s.goods_id", goodIds).GroupBy("s.goods_id").Find(&ms)
// ms := make([]map[string]int, 0)
// err = s.Table(&models.CustomerOrderSub{}).Alias("s").Select("s.goods_id, COALESCE(SUM(s.goods_num), 0) as goods_num").
// Join("left", (&models.CustomerOrder{}).Alias("o"), "o.id=s.order_id").
// Where("o.activity_id=? and o.rehearsal_id=? and o.arch_id=?", activity.Id, activity.RehearsalId, activity.ArchId).
// In("s.goods_id", goodIds).GroupBy("s.goods_id").Find(&ms)
ms, err := models.GetSubOrderGoodNumBySession(s, goodIds)
if err != nil { if err != nil {
s.Rollback() s.Rollback()
t.CheckErr(err) t.CheckErr(err)
@ -356,7 +362,7 @@ func (t *OrderEntryCtl) ManualOrder() {
if g.Stock == -1 { // 无上限 if g.Stock == -1 { // 无上限
break break
} }
if m["goods_id"] == int(g.Id) && m["goods_num"] >= g.Stock {
if m.GoodsId == g.Id && g.Stock-m.GoodsNum <= 0 {
s.Rollback() s.Rollback()
t.ERROR(g.Name+"商品库存不足", code.MSG_CUSTOMER_GOOD_NOT_ENOUGH) t.ERROR(g.Name+"商品库存不足", code.MSG_CUSTOMER_GOOD_NOT_ENOUGH)
return return

Loading…
Cancel
Save