From c6e4c58288053493fe62c9a390dfdf8cf1bedf98 Mon Sep 17 00:00:00 2001
From: liujiandao <274878379@qq.com>
Date: 星期三, 17 四月 2024 13:57:50 +0800
Subject: [PATCH] 产品添加字段2

---
 controllers/operation.go |   51 ++++++++++++++++++++++++-
 docs/swagger.yaml        |   10 +++++
 request/operation.go     |    2 +
 docs/docs.go             |   14 +++++++
 docs/swagger.json        |   14 +++++++
 5 files changed, 89 insertions(+), 2 deletions(-)

diff --git a/controllers/operation.go b/controllers/operation.go
index 450d03c..af53200 100644
--- a/controllers/operation.go
+++ b/controllers/operation.go
@@ -916,12 +916,12 @@
 	readerCloser.Close()
 	defer f.Close()
 
-	f.SetCellValue("Sheet1", "C2", operation.CompanyName)
 	f.SetCellValue("Sheet1", "H2", operation.OperationDate)
 	f.SetCellValue("Sheet1", "O2", operation.Number)
 
 	rowIndex := 5
 	totalAmount := decimal.NewFromInt(0)
+	//totalPrice := decimal.NewFromInt(0)
 	for i, v := range operation.Details {
 		//璁剧疆琛ㄥ崟鏈�澶�9鏉℃暟鎹�
 		if i > 8 {
@@ -931,10 +931,57 @@
 		f.SetCellValue("Sheet1", "B"+strconv.Itoa(rowIndex), v.Product.Type)
 		f.SetCellValue("Sheet1", "C"+strconv.Itoa(rowIndex), v.Product.Unit)
 		f.SetCellValue("Sheet1", "D"+strconv.Itoa(rowIndex), v.Amount.String())
+		f.SetCellValue("Sheet1", "E"+strconv.Itoa(rowIndex), v.Product.PurchasePrice.String())
+		if !v.Product.PurchasePrice.IsZero() {
+			//totalPrice = totalPrice.Add(v.Product.PurchasePrice)
+			price := v.Amount.Mul(v.Product.PurchasePrice).String()
+			split := strings.Split(price, ".")
+			if len(split) == 2 {
+				for n, a := range split[1] {
+					f.SetCellValue("Sheet1", string('M'+n)+strconv.Itoa(rowIndex), string(a))
+				}
+			} else {
+				f.SetCellValue("Sheet1", "M"+strconv.Itoa(rowIndex), "0")
+				f.SetCellValue("Sheet1", "N"+strconv.Itoa(rowIndex), "0")
+			}
+			s := split[0]
+			n := 0
+			for j := len(s) - 1; j >= 0; j-- {
+				if n == 6 {
+					f.SetCellValue("Sheet1", string('L'-n)+strconv.Itoa(rowIndex), s[:j])
+					break
+				}
+				f.SetCellValue("Sheet1", string('L'-n)+strconv.Itoa(rowIndex), string(s[j]))
+				n++
+			}
+		}
+
 		rowIndex++
 		totalAmount = totalAmount.Add(v.Amount)
 	}
-	f.SetCellValue("Sheet1", "D14", totalAmount)
+	//鍚堣
+	//if !totalPrice.IsZero() {
+	//	price := totalAmount.Mul(totalPrice).String()
+	//	split := strings.Split(price, ".")
+	//	if len(split) == 2 {
+	//		for n, a := range split[1] {
+	//			f.SetCellValue("Sheet1", string('M'+n)+"14", string(a))
+	//		}
+	//	}
+	//	s := split[0]
+	//	n := 0
+	//	for j := len(s) - 1; j >= 0; j-- {
+	//		if n == 6 {
+	//			f.SetCellValue("Sheet1", string('L'-n)+"14", s[:j])
+	//			break
+	//		}
+	//		f.SetCellValue("Sheet1", string('L'-n)+"14", string(s[j]))
+	//		n++
+	//	}
+	//}
+	//f.SetCellValue("Sheet1", "D14", totalAmount)
+	//f.SetCellValue("Sheet1", "E14", totalPrice)
+
 	f.SetCellValue("Sheet1", "B15", operation.Manager)
 	f.SetCellValue("Sheet1", "D15", operation.Accountant)
 	f.SetCellValue("Sheet1", "F15", operation.Custodian)
diff --git a/docs/docs.go b/docs/docs.go
index 6806e6e..fd049ed 100644
--- a/docs/docs.go
+++ b/docs/docs.go
@@ -3934,6 +3934,12 @@
                     "description": "ProductName string          ` + "`" + `json:\"productName\" gorm:\"type:varchar(255);not null;comment:浜у搧鍚嶇О\"` + "`" + ` //浜у搧鍚嶇О",
                     "type": "number"
                 },
+                "auxiliaryAmount": {
+                    "type": "number"
+                },
+                "auxiliaryUnit": {
+                    "type": "string"
+                },
                 "createTime": {
                     "type": "string"
                 },
@@ -4808,6 +4814,14 @@
                     "description": "ProductName string          ` + "`" + `json:\"productName\" gorm:\"type:varchar(255);not null;comment:浜у搧鍚嶇О\"` + "`" + ` //浜у搧鍚嶇О",
                     "type": "number"
                 },
+                "auxiliaryAmount": {
+                    "description": "杈呭姪鏁伴噺",
+                    "type": "number"
+                },
+                "auxiliaryUnit": {
+                    "description": "杈呭姪鍗曚綅",
+                    "type": "string"
+                },
                 "fromLocationId": {
                     "description": "Unit        string          ` + "`" + `json:\"unit\" gorm:\"type:varchar(31);comment:鍗曚綅\"` + "`" + `                    //鍗曚綅\nProduct models.Material ` + "`" + `json:\"product\" gorm:\"foreignKey:ProductId;references:ID\"` + "`" + `",
                     "type": "integer"
diff --git a/docs/swagger.json b/docs/swagger.json
index 2f1e070..880f4dc 100644
--- a/docs/swagger.json
+++ b/docs/swagger.json
@@ -3922,6 +3922,12 @@
                     "description": "ProductName string          `json:\"productName\" gorm:\"type:varchar(255);not null;comment:浜у搧鍚嶇О\"` //浜у搧鍚嶇О",
                     "type": "number"
                 },
+                "auxiliaryAmount": {
+                    "type": "number"
+                },
+                "auxiliaryUnit": {
+                    "type": "string"
+                },
                 "createTime": {
                     "type": "string"
                 },
@@ -4796,6 +4802,14 @@
                     "description": "ProductName string          `json:\"productName\" gorm:\"type:varchar(255);not null;comment:浜у搧鍚嶇О\"` //浜у搧鍚嶇О",
                     "type": "number"
                 },
+                "auxiliaryAmount": {
+                    "description": "杈呭姪鏁伴噺",
+                    "type": "number"
+                },
+                "auxiliaryUnit": {
+                    "description": "杈呭姪鍗曚綅",
+                    "type": "string"
+                },
                 "fromLocationId": {
                     "description": "Unit        string          `json:\"unit\" gorm:\"type:varchar(31);comment:鍗曚綅\"`                    //鍗曚綅\nProduct models.Material `json:\"product\" gorm:\"foreignKey:ProductId;references:ID\"`",
                     "type": "integer"
diff --git a/docs/swagger.yaml b/docs/swagger.yaml
index d32b9c0..c733427 100644
--- a/docs/swagger.yaml
+++ b/docs/swagger.yaml
@@ -853,6 +853,10 @@
         description: ProductName string          `json:"productName" gorm:"type:varchar(255);not
           null;comment:浜у搧鍚嶇О"` //浜у搧鍚嶇О
         type: number
+      auxiliaryAmount:
+        type: number
+      auxiliaryUnit:
+        type: string
       createTime:
         type: string
       fromLocation:
@@ -1453,6 +1457,12 @@
         description: ProductName string          `json:"productName" gorm:"type:varchar(255);not
           null;comment:浜у搧鍚嶇О"` //浜у搧鍚嶇О
         type: number
+      auxiliaryAmount:
+        description: 杈呭姪鏁伴噺
+        type: number
+      auxiliaryUnit:
+        description: 杈呭姪鍗曚綅
+        type: string
       fromLocationId:
         description: |-
           Unit        string          `json:"unit" gorm:"type:varchar(31);comment:鍗曚綅"`                    //鍗曚綅
diff --git a/request/operation.go b/request/operation.go
index d7ddc4c..df57d21 100644
--- a/request/operation.go
+++ b/request/operation.go
@@ -49,6 +49,8 @@
 	ToLocationId     int             `json:"toLocationId"    gorm:"type:int;not null;comment:鐩爣浣嶇疆id"` //鐩爣浣嶇疆id
 	TotalGrossWeight decimal.Decimal `json:"totalGrossWeight" gorm:"type:decimal(20,3);comment:鎬绘瘺閲�"`  //鎬绘瘺閲�
 	TotalNetWeight   decimal.Decimal `json:"totalNetWeight" gorm:"type:decimal(20,3);comment:鎬诲噣閲�"`    //鎬诲噣閲�
+	AuxiliaryAmount  decimal.Decimal `json:"auxiliaryAmount" gorm:"type:decimal(20,3);comment:杈呭姪鏁伴噺"`  //杈呭姪鏁伴噺
+	AuxiliaryUnit    string          `json:"auxiliaryUnit" gorm:"type:varchar(191);comment:杈呭姪鍗曚綅"`     //杈呭姪鍗曚綅
 }
 
 type OperationList struct {

--
Gitblit v1.8.0