zhangqian
2024-07-04 c950586b718ae6fc198bedf424609a4ac94cb5d1
controllers/location_product_amount.go
@@ -11,6 +11,7 @@
   "wms/constvar"
   "wms/extend/code"
   "wms/extend/util"
   "wms/middleware"
   "wms/models"
   "wms/pkg/mysqlx"
   "wms/request"
@@ -142,6 +143,52 @@
   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.Response   "成功"
// @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
   }
   util.ResponseFormatList(c, code.Success, records, int(total))
}
// Add
// @Tags      库存盘点
// @Summary   添加库存盘点信息
@@ -155,8 +202,8 @@
      util.ResponseFormat(c, code.RequestParamError, "参数解析失败,数据类型错误")
      return
   }
   if err := AddLocationProductAmount(reqParams); err != nil {
   userInfo := middleware.GetUserInfo(c)
   if err := AddLocationProductAmount(reqParams, userInfo); err != nil {
      util.ResponseFormat(c, code.RequestError, err)
      return
   }
@@ -164,7 +211,7 @@
   util.ResponseFormat(c, code.Success, "添加成功")
}
func AddLocationProductAmount(reqParams request.UpdateLocationProductAmount) error {
func AddLocationProductAmount(reqParams request.UpdateLocationProductAmount, userInfo *request.CustomClaims) error {
   if reqParams.LocationId == 0 {
      return errors.New("参数异常,位置id信息不存在")
   }
@@ -219,6 +266,7 @@
      Details:           []*models.OperationDetails{detail},
      LocationID:        location.Id,
      OperationTypeName: "库存调整",
      CreatedBy:         userInfo.Username,
   }
   if err := models.WithTransaction(func(tx *gorm.DB) error {
@@ -278,8 +326,9 @@
      util.ResponseFormat(c, code.RequestParamError, "参数解析失败,数据类型错误")
      return
   }
   userInfo := middleware.GetUserInfo(c)
   if reqParams.OperationId == 0 {
      if err := AddLocationProductAmount(reqParams); err != nil {
      if err := AddLocationProductAmount(reqParams, userInfo); err != nil {
         util.ResponseFormat(c, code.RequestError, err.Error())
         return
      }
@@ -349,8 +398,11 @@
      return
   }
   adjustAmount := operation.Details[0].Amount.Sub(locProductAmount.Amount)
   userInfo := middleware.GetUserInfo(c)
   if err := models.WithTransaction(func(tx *gorm.DB) error {
      if err := models.NewOperationSearch().SetOrm(tx).SetID(reqParams.OperationId).Update(&models.Operation{Status: constvar.OperationStatus_Finish}); err != nil {
      if err := models.NewOperationSearch().SetOrm(tx).SetID(reqParams.OperationId).Update(&models.Operation{
         Status: constvar.OperationStatus_Finish, CheckedBy: userInfo.Username,
         AuditDate: time.Now().Format("2006-01-02 15:04:05")}); err != nil {
         return err
      }
      if err := models.NewMaterialSearch().SetOrm(tx).SetID(reqParams.ProductId).Update(&models.Material{Amount: material.Amount.Add(adjustAmount)}); err != nil {