From ae6883ce426727efca4facab973d814ae66c69c2 Mon Sep 17 00:00:00 2001
From: zhangqian <zhangqian@123.com>
Date: 星期五, 11 八月 2023 16:50:08 +0800
Subject: [PATCH] Merge branch 'master' of ssh://192.168.5.5:29418/aps/crm

---
 api/v1/collectionProjection.go |  138 ++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 138 insertions(+), 0 deletions(-)

diff --git a/api/v1/collectionProjection.go b/api/v1/collectionProjection.go
new file mode 100644
index 0000000..2caa97b
--- /dev/null
+++ b/api/v1/collectionProjection.go
@@ -0,0 +1,138 @@
+package v1
+
+import (
+	"aps_crm/model"
+	"aps_crm/model/request"
+	"aps_crm/model/response"
+	"aps_crm/pkg/contextx"
+	"aps_crm/pkg/ecode"
+	"github.com/gin-gonic/gin"
+	"strconv"
+)
+
+type CollectionProjectionApi struct{}
+
+// Add
+//
+//	@Tags		CollectionProjection
+//	@Summary	娣诲姞鏀舵棰勬祴
+//	@Produce	application/json
+//	@Param		object	body		request.AddCollectionProjection	true	"鏌ヨ鍙傛暟"
+//	@Success	200		{object}	contextx.Response{}
+//	@Router		/api/collectionProjection/add [post]
+func (cp *CollectionProjectionApi) Add(c *gin.Context) {
+	var params request.AddCollectionProjection
+	ctx, ok := contextx.NewContext(c, &params)
+	if !ok {
+		return
+	}
+
+	tmp := new(model.CollectionProjection)
+	tmp.EstimatedCollectionAmount = params.CollectionProjection.EstimatedCollectionAmount
+
+	if params.EstimatedCollectionTime == "" {
+		tmp.EstimatedCollectionDate = nil
+	} else {
+		tmp.EstimatedCollectionDate = &params.CollectionProjection.EstimatedCollectionTime
+	}
+
+	tmp.SaleChanceId = params.SaleChanceId
+
+	errCode := collectionProjectionService.AddCollectionProjection(tmp)
+	if errCode != ecode.OK {
+		ctx.Fail(errCode)
+		return
+	}
+
+	ctx.Ok()
+}
+
+// Delete
+//
+//	@Tags		CollectionProjection
+//	@Summary	鍒犻櫎鏀舵棰勬祴
+//	@Produce	application/json
+//	@Param		id	path		int	true	"鏌ヨ鍙傛暟"
+//	@Success	200	{object}	contextx.Response{}
+//	@Router		/api/collectionProjection/delete/{id} [delete]
+func (cp *CollectionProjectionApi) Delete(c *gin.Context) {
+	ctx, ok := contextx.NewContext(c, nil)
+	if !ok {
+		return
+	}
+
+	id, err := strconv.Atoi(c.Param("id"))
+	if err != nil {
+		ctx.Fail(ecode.InvalidParams)
+		return
+	}
+
+	errCode := collectionProjectionService.DeleteCollectionProjection(id)
+	if errCode != ecode.OK {
+		ctx.Fail(errCode)
+		return
+	}
+
+	ctx.Ok()
+}
+
+// Update
+//
+//	@Tags		CollectionProjection
+//	@Summary	鏇存柊鏀舵棰勬祴
+//	@Produce	application/json
+//	@Param		object	body		request.UpdateCollectionProjection	true	"鏌ヨ鍙傛暟"
+//	@Success	200		{object}	contextx.Response{}
+//	@Router		/api/collectionProjection/update [put]
+func (cp *CollectionProjectionApi) Update(c *gin.Context) {
+	var params request.UpdateCollectionProjection
+	ctx, ok := contextx.NewContext(c, &params)
+	if !ok {
+		return
+	}
+
+	tmp := new(model.CollectionProjection)
+	tmp.EstimatedCollectionAmount = params.CollectionProjection.EstimatedCollectionAmount
+	tmp.Id = params.Id
+
+	if params.EstimatedCollectionTime == "" {
+		tmp.EstimatedCollectionDate = nil
+	} else {
+		tmp.EstimatedCollectionDate = &params.CollectionProjection.EstimatedCollectionTime
+	}
+
+	errCode := collectionProjectionService.UpdateCollectionProjection(tmp)
+	if errCode != ecode.OK {
+		ctx.Fail(errCode)
+		return
+	}
+
+	ctx.Ok()
+}
+
+// List
+//
+//	@Tags		CollectionProjection
+//	@Summary	鑾峰彇鏀舵棰勬祴鍒楄〃
+//	@Produce	application/json
+//	@Param		object	query		request.GetCollectionProjectionList	true	"鏌ヨ鍙傛暟"
+//	@Success	200		{object}	contextx.Response{}
+//	@Router		/api/collectionProjection/list [post]
+func (cp *CollectionProjectionApi) List(c *gin.Context) {
+	var params request.GetCollectionProjectionList
+	ctx, ok := contextx.NewContext(c, &params)
+	if !ok {
+		return
+	}
+
+	total, errCode, list := collectionProjectionService.GetCollectionProjectionList(params.Page, params.PageSize, params.SearchMap)
+	if errCode != ecode.OK {
+		ctx.Fail(errCode)
+		return
+	}
+
+	ctx.OkWithDetailed(response.CollectionProjectionListResponse{
+		List:  list,
+		Count: int(total),
+	})
+}

--
Gitblit v1.8.0