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, &params)
+	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