liujiandao
2023-10-24 6aa75c2a266a2522ae713b13dc702b5ad0a08f87
api/v1/salesRefund.go
@@ -1,20 +1,23 @@
package v1
import (
   "aps_crm/constvar"
   "aps_crm/model"
   "aps_crm/model/request"
   "aps_crm/model/response"
   "aps_crm/pkg/contextx"
   "aps_crm/pkg/ecode"
   "aps_crm/utils"
   "github.com/gin-gonic/gin"
   "strconv"
   "strings"
)
type SalesRefundApi struct{}
// Add
//
//   @Tags      SalesRefund
//   @Tags      销售退款单
//   @Summary   添加销售退款
//   @Produce   application/json
//   @Param      object   body      request.AddSalesRefundRequest   true   "查询参数"
@@ -33,6 +36,23 @@
      return
   }
   count, err := model.NewSalesRefundSearch().SetNumber(salesRefund.Number).Count()
   if err != nil {
      ctx.FailWithMsg(ecode.UnknownErr, "编码验证失败")
      return
   }
   if count > 0 {
      ctx.FailWithMsg(ecode.UnknownErr, "编码已存在")
      return
   }
   if salesRefund.MemberId == 0 {
      userInfo := utils.GetUserInfo(c)
      if userInfo.UserType == constvar.UserTypeSub {
         salesRefund.MemberId = userInfo.CrmUserId
      }
   }
   errCode = salesRefundService.AddSalesRefund(&salesRefund)
   if errCode != ecode.OK {
      ctx.Fail(errCode)
@@ -44,7 +64,7 @@
// Delete
//
//   @Tags      SalesRefund
//   @Tags      销售退款单
//   @Summary   删除销售退款
//   @Produce   application/json
//   @Param      id   path      int   true   "查询参数"
@@ -66,9 +86,40 @@
   ctx.Ok()
}
// BatchDelete
// @Tags   销售退款单
// @Summary   批量删除销售退款单
// @Produce   application/json
// @Param   object   body request.CommonIds   true "参数"
// @Success   200   {object}   contextx.Response{}
// @Router      /api/salesRefund/delete [delete]
func (s *SalesRefundApi) BatchDelete(c *gin.Context) {
   var params request.CommonIds
   ctx, ok := contextx.NewContext(c, &params)
   if !ok {
      return
   }
   failIds, _ := salesRefundService.BatchDeleteSalesRefund(params.Ids)
   if len(failIds) == 0 {
      ctx.Ok()
      return
   }
   salesReturns, code := salesRefundService.GetSalesRefundListByIds(failIds)
   if code != ecode.OK {
      ctx.Ok()
      return
   }
   var numbers []string
   for _, salesReturn := range salesReturns {
      numbers = append(numbers, salesReturn.Number)
   }
   ctx.FailWithMsg(ecode.DBErr, strings.Join(numbers, ",")+"删除失败")
}
// Update
//
//   @Tags      SalesRefund
//   @Tags      销售退款单
//   @Summary   更新销售退款
//   @Produce   application/json
//   @Param      object   body      request.UpdateSalesRefundRequest   true   "查询参数"
@@ -108,13 +159,16 @@
   salesRefundRes.IsInvoice = salesRefund.IsInvoice
   salesRefundRes.Reason = salesRefund.Reason
   salesRefundRes.Products = salesRefund.Products
   salesRefundRes.SourceType = salesRefund.SourceType
   salesRefundRes.SourceId = salesRefund.SourceId
   salesRefundRes.CodeStandID = salesRefund.CodeStandID
   return ecode.OK, salesRefundRes
}
// List
//
//   @Tags      SalesRefund
//   @Tags      销售退款单
//   @Summary   销售退款单列表
//   @Produce   application/json
//   @Param      object   body      request.GetSalesRefundList   true   "参数"
@@ -127,7 +181,13 @@
      return
   }
   salesRefunds, total, errCode := salesRefundService.GetSalesRefundList(params.Page, params.PageSize, params.Keyword)
   var memberIds []int
   userInfo := utils.GetUserInfo(c)
   if userInfo.UserType == constvar.UserTypeSub {
      memberIds = []int{userInfo.CrmUserId}
   }
   salesRefunds, total, errCode := salesRefundService.GetSalesRefundList(params.Page, params.PageSize, params.KeywordType, params.Keyword, params.SourceId, memberIds)
   if errCode != ecode.OK {
      ctx.Fail(errCode)
      return