From 73b6baf6af3d88cdcb0e2df7932a9bd96b0b85c5 Mon Sep 17 00:00:00 2001
From: zhangqian <zhangqian@123.com>
Date: 星期一, 01 七月 2024 22:32:34 +0800
Subject: [PATCH] 月度统计出入库按类型汇总报表定时任务和手动跑任务接口

---
 models/operation.go |   27 ++++++++++++++++++++++-----
 1 files changed, 22 insertions(+), 5 deletions(-)

diff --git a/models/operation.go b/models/operation.go
index 36b2391..826208d 100644
--- a/models/operation.go
+++ b/models/operation.go
@@ -61,10 +61,11 @@
 		CheckedBy    string `json:"checkedBy" gorm:"type:varchar(255);comment:楠岃瘉鑰匲serId"`
 		Remark       string `json:"remark"`
 
-		WarehouseId         int      `json:"warehouseId" gorm:"type:int;not null;comment:浠撳簱id"`
-		IsInternalOutput    bool     `json:"isInternalOutput"` //鏄惁璋冩嫧浜х敓鐨勫嚭搴�
-		InventoryDealerType int      `json:"inventoryDealerType" gorm:"type:varchar(255);comment:璋冩嫧鍑哄叆搴撳垎绫�(瀵瑰簲dict瀛楀吀琛ㄧ殑ID)"`
-		InventoryDealer     MiniDict `json:"inventoryDealer" gorm:"foreignKey:InventoryDealerType;"`
+		WarehouseId         int       `json:"warehouseId" gorm:"type:int;not null;comment:浠撳簱id"`
+		Warehouse           Warehouse `json:"warehouse" gorm:"foreignKey:WarehouseId"`
+		IsInternalOutput    bool      `json:"isInternalOutput"` //鏄惁璋冩嫧浜х敓鐨勫嚭搴�
+		InventoryDealerType int       `json:"inventoryDealerType" gorm:"type:varchar(255);comment:璋冩嫧鍑哄叆搴撳垎绫�(瀵瑰簲dict瀛楀吀琛ㄧ殑ID)"`
+		InventoryDealer     MiniDict  `json:"inventoryDealer" gorm:"foreignKey:InventoryDealerType;"`
 	}
 
 	OperationSearch struct {
@@ -195,6 +196,11 @@
 	return slf
 }
 
+func (slf *OperationSearch) SetWarehouseId(warehouseId int) *OperationSearch {
+	slf.WarehouseId = warehouseId
+	return slf
+}
+
 func (slf *OperationSearch) build() *gorm.DB {
 	var db = slf.Orm.Model(&Operation{})
 
@@ -226,7 +232,14 @@
 	}
 
 	if slf.Preload {
-		db = db.Model(&Operation{}).Preload("Details").Preload("Details.Product").Preload("LogisticCompany").Preload("Location").Preload("ToLocation").Preload("Details.FromLocation").Preload("Details.ToLocation").Preload("InventoryDealer")
+		db = db.Model(&Operation{}).Preload("Details").
+			Preload("Details.Product").
+			Preload("LogisticCompany").
+			Preload("Location").
+			Preload("ToLocation").
+			Preload("Details.FromLocation").
+			Preload("Details.ToLocation").
+			Preload("InventoryDealer").Preload("Warehouse")
 	}
 
 	if slf.Disuse {
@@ -269,6 +282,10 @@
 		db = db.Where("inventory_dealer_type in (?)", slf.InventoryDealerTypeIds)
 	}
 
+	if slf.WarehouseId != 0 {
+		db = db.Where("warehouse_id = ?", slf.WarehouseId)
+	}
+
 	return db
 }
 

--
Gitblit v1.8.0