From 7438f17c0b3a9f79ee5890c554bedc64c362859b Mon Sep 17 00:00:00 2001 From: zhangqian <zhangqian@123.com> Date: 星期五, 13 十月 2023 14:04:59 +0800 Subject: [PATCH] 销售计划简单数据权限 --- api/v1/salesReturn.go | 76 ++++++++++++++++++++++---------------- 1 files changed, 44 insertions(+), 32 deletions(-) diff --git a/api/v1/salesReturn.go b/api/v1/salesReturn.go index 5ada12a..afc1355 100644 --- a/api/v1/salesReturn.go +++ b/api/v1/salesReturn.go @@ -6,15 +6,17 @@ "aps_crm/model/response" "aps_crm/pkg/contextx" "aps_crm/pkg/ecode" + "aps_crm/pkg/structx" "github.com/gin-gonic/gin" "strconv" + "strings" ) type SalesReturnApi struct{} // Add // -// @Tags SalesReturn +// @Tags 閿�鍞��璐у崟 // @Summary 娣诲姞閿�鍞��璐� // @Produce application/json // @Param object body request.AddSalesReturnRequest true "鏌ヨ鍙傛暟" @@ -44,7 +46,7 @@ // Delete // -// @Tags SalesReturn +// @Tags 閿�鍞��璐у崟 // @Summary 鍒犻櫎閿�鍞��璐� // @Produce application/json // @Param id path int true "鏌ヨ鍙傛暟" @@ -66,9 +68,39 @@ ctx.Ok() } +// BatchDelete +// @Tags 閿�鍞��璐у崟 +// @Summary 鎵归噺鍒犻櫎閿�鍞��璐у崟 +// @Produce application/json +// @Param object body request.CommonIds true "鍙傛暟" +// @Success 200 {object} contextx.Response{} +// @Router /api/salesReturn/delete [delete] +func (s *SalesReturnApi) BatchDelete(c *gin.Context) { + var params request.CommonIds + ctx, ok := contextx.NewContext(c, ¶ms) + if !ok { + return + } + failIds, _ := salesReturnService.BatchDeleteSalesReturn(params.Ids) + if len(failIds) == 0 { + ctx.Ok() + return + } + salesReturns, code := salesReturnService.GetSalesReturnListByIds(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 SalesReturn +// @Tags 閿�鍞��璐у崟 // @Summary 鏇存柊閿�鍞��璐� // @Produce application/json // @Param object body request.UpdateSalesReturnRequest true "鏌ヨ鍙傛暟" @@ -99,43 +131,23 @@ } - func checkSalesReturnParams(salesReturn request.SalesReturn) (errCode int, s model.SalesReturn) { - //if salesReturn.Number == "" { - // return ecode.InvalidParams, s - //} - // - //if salesReturn.Repository == "" { - // return ecode.InvalidParams, s - //} - // - //if salesReturn.MemberId == 0 { - // return ecode.InvalidParams, s - //} - - t, err := checkTimeFormat(salesReturn.ReturnDate) + err := structx.AssignTo(salesReturn, &s) if err != nil { - return ecode.InvalidParams, s + return ecode.ParamsErr, s } - - s.ClientId = salesReturn.ClientId - s.ReturnDate = t - s.Number = salesReturn.Number - s.Repository = salesReturn.Repository - s.MemberId = salesReturn.MemberId - s.SalesReturnStatus = salesReturn.Status - s.Reason = salesReturn.Reason - s.Products = salesReturn.Products return ecode.OK, s } // List // -// @Tags SalesReturn +// @Tags 閿�鍞��璐у崟 // @Summary 閿�鍞��璐у崟鍒楄〃 // @Produce application/json -// @Param object body request.GetSalesReturnList true "鍙傛暟" +// +// @Param object body request.GetSalesReturnList true "鍙傛暟" +// // @Success 200 {object} contextx.Response{data=response.SalesReturnResponse} // @Router /api/salesReturn/list [post] func (con *SalesReturnApi) List(c *gin.Context) { @@ -145,14 +157,14 @@ return } - salesReturns, errCode := salesReturnService.GetSalesReturnList(params.Page, params.PageSize, params.Keyword) + salesReturns, total, errCode := salesReturnService.GetSalesReturnList(params.Page, params.PageSize, params.KeywordType, params.Keyword) if errCode != ecode.OK { ctx.Fail(errCode) return } ctx.OkWithDetailed(response.SalesReturnResponse{ - List: salesReturns, - Count: len(salesReturns), + List: salesReturns, + Count: int(total), }) } -- Gitblit v1.8.0