From f1842bf9b5bb69b5078a215c02cb16b7e33f893a Mon Sep 17 00:00:00 2001
From: zhangqian <zhangqian@123.com>
Date: 星期一, 08 一月 2024 14:38:46 +0800
Subject: [PATCH] Merge branch 'master' of http://192.168.5.5:10010/r/aps/crm

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

diff --git a/api/v1/quotation.go b/api/v1/quotation.go
index d237955..ecbe7da 100644
--- a/api/v1/quotation.go
+++ b/api/v1/quotation.go
@@ -9,6 +9,7 @@
 	"aps_crm/pkg/ecode"
 	"aps_crm/utils"
 	"github.com/gin-gonic/gin"
+	"github.com/shopspring/decimal"
 )
 
 type QuotationApi struct{}
@@ -195,8 +196,43 @@
 		return
 	}
 
+	for _, quotation := range quotations {
+		amount := decimal.NewFromInt(0)
+		for _, product := range quotation.Products {
+			amount = amount.Add(product.Total)
+		}
+		quotation.AmountTotal = amount
+	}
+
 	ctx.OkWithDetailed(response.QuotationResponse{
 		List:  quotations,
 		Count: int(total),
 	})
 }
+
+// Statistics
+//
+//	@Tags		Quotation
+//	@Summary	鎶ヤ环鍗曠粺璁�
+//	@Produce	application/json
+//	@Success	200		{object}	contextx.Response{data=map[string]int64}
+//	@Router		/api/quotation/statistics [get]
+func (con *QuotationApi) Statistics(c *gin.Context) {
+	ctx, ok := contextx.NewContext(c, nil)
+	if !ok {
+		return
+	}
+	m := make(map[string]int64)
+	total, _ := model.NewQuotationSearch(nil).Count()
+	m["total"] = total
+	//宸插垱寤�
+	created, _ := model.NewQuotationSearch(nil).SetQuotationStatusId(1).Count()
+	m["created"] = created
+	//宸插鎵�
+	approved, _ := model.NewQuotationSearch(nil).SetQuotationStatusId(3).Count()
+	m["approved"] = approved
+	//宸叉帴鍙�
+	accepted, _ := model.NewQuotationSearch(nil).SetQuotationStatusId(5).Count()
+	m["accepted"] = accepted
+	ctx.OkWithDetailed(m)
+}

--
Gitblit v1.8.0