From cacf363f222e354cad6db18c4a00fb1097d35c2c Mon Sep 17 00:00:00 2001
From: zhangqian <zhangqian@123.com>
Date: 星期四, 09 十一月 2023 14:30:58 +0800
Subject: [PATCH] fix

---
 service/process_model.go |   30 ++++++++++++++++++++++++++----
 1 files changed, 26 insertions(+), 4 deletions(-)

diff --git a/service/process_model.go b/service/process_model.go
index c4ff7dd..1922fce 100644
--- a/service/process_model.go
+++ b/service/process_model.go
@@ -3,15 +3,37 @@
 import (
 	"apsClient/conf"
 	"apsClient/model"
+	"apsClient/pkg/logx"
+	"errors"
 )
 
-func GetProcessModelList(page, pageSize int) (list []*model.ProcessModel, total int64, err error) {
-	device, err := model.NewDeviceSearch().SetDeviceId(conf.Conf.System.DeviceId).First()
+func GetProcessModelList(offset, limit int, currentNumber string) (list []*model.ProcessModel, total int64, err error) {
+	device, err := model.NewDeviceSearch().SetDeviceId(conf.Conf.CurrentDeviceID).First()
 	if err != nil {
 		return
 	}
 	list, total, err = model.NewProcessModelSearch().
-		SetIsNew(true).SetOrder("id desc").
-		SetPage(page, pageSize).SetProcedures(device.ProceduresArr).Find()
+		SetIsNew(true).SetOrder("id desc").SetCurrentNumber(currentNumber).
+		SetPage(offset, limit).SetProcedures(device.ProceduresArr).Find()
 	return
 }
+
+func GetProcessModelByNumber(num string) (record *model.ProcessModel, err error) {
+	return model.NewProcessModelSearch().SetNumber(num).First()
+}
+
+func GetProcessModelAddress(deviceID string) (addressMap map[string]int, err error) {
+	record, err := model.NewProcessModelPlcAddressSearch().SetDeviceID(deviceID).First()
+	if err != nil {
+		logx.Errorf("find process model plc address for device:%v, err:%v", deviceID, err)
+		return nil, err
+	}
+	if record.AddressList == nil {
+		return nil, errors.New("empty process model address list")
+	}
+	addressMap = make(map[string]int, len(record.AddressList))
+	for _, item := range record.AddressList {
+		addressMap[item.Name] = item.Address
+	}
+	return addressMap, nil
+}

--
Gitblit v1.8.0