yinbentan
2024-07-06 79aef24a785581d95343ccd99e9cb362b2bc9c97
controllers/location_product_amount.go
@@ -4,6 +4,7 @@
   "errors"
   "fmt"
   "github.com/gin-gonic/gin"
   "github.com/mitchellh/mapstructure"
   "github.com/shopspring/decimal"
   "gorm.io/gorm"
   "strconv"
@@ -143,6 +144,65 @@
   util.ResponseFormatListWithPage(c, code.Success, records, int(total), params.Page, params.PageSize)
}
// LocationProductList
// @Tags      库存盘点
// @Summary   获取位置对应产品列表
// @Produce   application/json
// @Param       object  body  request.GetLocationProductList true  "查询参数"
// @Param     Authorization   header string true "token"
// @Success   200 {object} util.ResponseList(data=[]*response.LocationProductAmount)   "成功"
// @Router    /api-wms/v1/locationProductAmount/locationProductList [post]
func (slf LocationProductAmountController) LocationProductList(c *gin.Context) {
   var params request.GetLocationProductList
   if err := c.BindJSON(&params); err != nil {
      util.ResponseFormat(c, code.RequestParamError, "参数解析失败,数据类型错误:"+err.Error())
      return
   }
   if !params.Check() {
      util.ResponseFormat(c, code.RequestParamError, "参数异常")
      return
   }
   productIds := make([]string, 0)
   locationIds := make([]int, 0)
   if params.Keyword != "" {
      materials, _ := models.NewMaterialSearch().SetKeyword(params.Keyword).FindNotTotal()
      for _, material := range materials {
         productIds = append(productIds, material.ID)
      }
      locations, _ := models.NewLocationSearch().SetKeyword(params.Keyword).FindNotTotal()
      for _, location := range locations {
         locationIds = append(locationIds, location.Id)
      }
   }
   search := models.NewLocationProductAmountSearch()
   records, total, err := search.
      SetLocationIds(locationIds).SetWarehouseId(params.WarehouseId).SetProductIds(productIds).SetLocationId(params.LocationId).
      SetPage(params.Page, params.PageSize).
      SetOrder("id desc").
      SetPreload(true).
      FindByPage()
   if err != nil {
      util.ResponseFormat(c, code.InternalError, "查询失败")
      return
   }
   dataList := make([]*response.LocationProductAmount, 0, len(records))
   for _, v := range records {
      data := new(response.LocationProductAmount)
      mapstructure.Decode(v.Product, &data)
      data.ID = v.ProductId
      data.LocationId = v.LocationId
      data.Location = v.Location
      data.Amount = v.Amount
      data.ProductId = v.ProductId
      dataList = append(dataList, data)
   }
   util.ResponseFormatList(c, code.Success, dataList, int(total))
}
// Add
// @Tags      库存盘点
// @Summary   添加库存盘点信息
@@ -202,6 +262,7 @@
         ProductId:         reqParams.ProductId,
         Amount:            decimal.NewFromInt(0),
         CreateDate:        time.Now().Format("2006-01-02 15:04:05"),
         WarehouseId:       location.WarehouseId,
      }
   }