广汽安道拓Acura项目MES后台
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

474 lines
15 KiB

// Copyright (c) Shenyang Leading Edge Intelligent Technology Co., Ltd. All rights reserved.
package implments
import (
baseDal "LAPP_ACURA_MOM_BACKEND/dao/base"
dal "LAPP_ACURA_MOM_BACKEND/dao/pm"
"LAPP_ACURA_MOM_BACKEND/db"
"LAPP_ACURA_MOM_BACKEND/global"
"LAPP_ACURA_MOM_BACKEND/grmi"
meta "LAPP_ACURA_MOM_BACKEND/meta/pm"
model "LAPP_ACURA_MOM_BACKEND/models/pm"
"LAPP_ACURA_MOM_BACKEND/utils"
)
/******************************************************************************
*
* @Description : Template的默认查询条件
*
* @Author : 代码生成器创建
*
* @Date : 2021-10-08 13:20:42
*
******************************************************************************/
var DefaultConditionOfTemplate = grmi.NewCondition(
map[string]grmi.ConditionItem{
meta.Template_MainTemplateNr.UrlParameterName: grmi.NewConditionItem(meta.Template_MainTemplateNr, grmi.Equal, true),
meta.Template_Descr.UrlParameterName: grmi.NewConditionItem(meta.Template_Descr, grmi.Equal, false),
meta.Template_TrackByDateToggle.UrlParameterName: grmi.NewConditionItem(meta.Template_TrackByDateToggle, grmi.Equal, false),
meta.Template_TrackByPriMeterToggle.UrlParameterName: grmi.NewConditionItem(meta.Template_TrackByPriMeterToggle, grmi.Equal, false),
meta.Template_PriMeterUom.UrlParameterName: grmi.NewConditionItem(meta.Template_PriMeterUom, grmi.Equal, false),
meta.Template_TrackBySecMeterToggle.UrlParameterName: grmi.NewConditionItem(meta.Template_TrackBySecMeterToggle, grmi.Equal, false),
meta.Template_SecMeterUom.UrlParameterName: grmi.NewConditionItem(meta.Template_SecMeterUom, grmi.Equal, false),
meta.Template_LastModify.UrlParameterName: grmi.NewConditionItem(meta.Template_LastModify, grmi.Approximate, false),
meta.Template_LastUser.UrlParameterName: grmi.NewConditionItem(meta.Template_LastUser, grmi.Equal, false),
meta.Template_CreateTime.UrlParameterName: grmi.NewConditionItem(meta.Template_CreateTime, grmi.Approximate, false),
},
nil,
)
/******************************************************************************
*
* @Description : Template的默认分页查询条件
*
* @Author : 代码生成器创建
*
* @Date : 2021-10-08 13:20:42
*
******************************************************************************/
var DefaultConditionOfTemplateAndPaging = grmi.NewCondition(
DefaultConditionOfTemplate.Items,
grmi.NewPaging(),
)
/******************************************************************************
*
* @Struct Name : TemplateServiceImplement
*-----------------------------------------------------------------------------
*
* @Description : Template的服务实现
*
* @Author : 代码生成器创建
*
* @Date : 2021-10-08 13:20:42
*
******************************************************************************/
type TemplateServiceImplement struct {
}
/******************************************************************************
*
* @Function Name : NewTemplateDAOImplement
*-----------------------------------------------------------------------------
*
* @Description : 创建一个TemplateDAOImplement实例
*
* @Return Value : TemplateDAOImplement实例
*
* @Author : 代码生成器创建
*
* @Date : 2021-10-08 13:20:42
*
******************************************************************************/
func NewTemplateServiceImplement() *TemplateServiceImplement {
return &TemplateServiceImplement{}
}
/******************************************************************************
*
* @Reference LAPP_ACURA_MOM_BACKEND/services/pm/TemplateService.InsertOne
*
******************************************************************************/
func (impl *TemplateServiceImplement) InsertOne(user *global.User, entity *model.Template) error {
grmi.Log(user, "/services/pm/implments/Template.service.impl.go", "InsertOneTemplate", "插入一个Template")
engine := db.Eloquent.Master()
session := engine.NewSession()
defer session.Close()
err := session.Begin()
if err != nil {
return err
}
dao := dal.NewTemplateDAO(session, user.PlantNr, user.UserId)
record, err := dao.SelectOne(entity.MainTemplateNr)
if err != nil {
return err
}
if record != nil {
session.Rollback()
return grmi.NewBusinessError("已经存在相同主键的记录!")
}
snrDao := baseDal.NewSnrDAO(session, user.PlantNr, user.UserId)
Maintemplatenr, err := snrDao.GetNextSnr("Templateid")
if err != nil {
session.Rollback()
return err
}
entity.MainTemplateNr = utils.ValueToInt(Maintemplatenr,0)
err = dao.InsertOne(entity)
if err != nil {
session.Rollback()
return err
}
//批量插入
alldata := make([]model.TemplateServiceLst, 0)
for k, v := range entity.Valst {
one := model.TemplateServiceLst{}
one.PlantNr = entity.PlantNr
one.Pos = k + 1
one.Descr = v.Descr
one.MainTemplateNr = entity.MainTemplateNr
one.MainServiceNr = utils.ValueToInt(v.MainServiceNr, 0)
one.CreateTime = entity.CreateTime
one.LastUser = entity.LastUser
one.LastModify = entity.LastModify
alldata = append(alldata, one)
}
_, err = session.Table("PM_TemplateServiceLst").Insert(&alldata)
if err != nil {
session.Rollback()
return err
}
err = session.Commit()
if err != nil {
return err
}
return nil
}
/******************************************************************************
*
* @Reference LAPP_ACURA_MOM_BACKEND/services/pm/TemplateService.DeleteOne
*
******************************************************************************/
func (impl *TemplateServiceImplement) DeleteOne(user *global.User, mainTemplateNr int) error {
grmi.Log(user, "/services/pm/implments/Template.service.impl.go", "DeleteOneTemplate", "删除一个Template")
engine := db.Eloquent.Master()
session := engine.NewSession()
defer session.Close()
err := session.Begin()
if err != nil {
return err
}
dao := dal.NewTemplateDAO(session, user.PlantNr, user.UserId)
record, err := dao.SelectOne(mainTemplateNr)
if err != nil {
return err
}
if record == nil {
return grmi.NewBusinessError("不存在指定记录!")
}
err = dao.DeleteOne(mainTemplateNr)
if err != nil {
session.Rollback()
return err
}
dao_TemplateServiceLst := dal.NewTemplateServiceLstDAO(session, user.PlantNr, user.UserId)
err = dao_TemplateServiceLst.DeleteWhere([]grmi.Predicate{meta.TemplateServiceLst_PlantNr.NewPredicate(grmi.Equal, record.PlantNr), meta.TemplateServiceLst_MainTemplateNr.NewPredicate(grmi.Equal, record.MainTemplateNr)})
if err != nil {
session.Rollback()
return err
}
err = session.Commit()
if err != nil {
return err
}
return nil
}
/******************************************************************************
*
* @Reference LAPP_ACURA_MOM_BACKEND/services/pm/TemplateService.SelectOne
*
******************************************************************************/
func (impl *TemplateServiceImplement) SelectOne(user *global.User, mainTemplateNr int) (*model.Template, error) {
grmi.Log(user, "/services/pm/implments/Template.service.impl.go", "SelectOneTemplate", "查询一个Template")
engine := db.Eloquent.Master()
session := engine.NewSession()
defer session.Close()
dao := dal.NewTemplateDAO(session, user.PlantNr, user.UserId)
result, err := dao.SelectOne(mainTemplateNr)
if err != nil {
return nil, err
}
if result == nil{
return result, err
}
var datalist []model.Service
var tem1 []model.Service
var tem2 []model.TemplateServiceLst
var maintemplatenrs []int
err = session.Table("PM_Service").Find(&tem1)
if err != nil {
return result, err
}
err = session.Table("PM_TemplateServiceLst").Find(&tem2)
if err != nil {
return result, err
}
var Maintemplatenrs []int
for _, v := range tem1 {
for _, v2 := range tem2{
if v.PlantNr == v2.PlantNr && v.MainServiceNr == v2.MainServiceNr{
dataone := model.Service{}
dataone.MainServiceNr = v.MainServiceNr
dataone.Descr = v.Descr
maintemplatenrs = append(maintemplatenrs, v2.MainTemplateNr)
datalist = append(datalist, dataone)
}
}
}
result.Valst = datalist
var templatedata []model.Service
err = session.Table("PM_Service").NotIn("MainServiceNr", Maintemplatenrs).Where("PlantNr = ?", result.PlantNr).Find(&templatedata)
if err != nil {
return result, err
}
result.UnValst = templatedata
return result, nil
}
/******************************************************************************
*
* @Reference LAPP_ACURA_MOM_BACKEND/services/pm/TemplateService.UpdateOne
*
******************************************************************************/
func (impl *TemplateServiceImplement) UpdateOne(user *global.User, entity *model.Template) error {
grmi.Log(user, "/services/pm/implments/Template.service.impl.go", "UpdateOneTemplate", "修改一个Template")
engine := db.Eloquent.Master()
session := engine.NewSession()
defer session.Close()
err := session.Begin()
if err != nil {
return err
}
dao := dal.NewTemplateDAO(session, user.PlantNr, user.UserId)
record, err := dao.SelectOne(entity.MainTemplateNr)
if err != nil {
return err
}
if record == nil {
return grmi.NewBusinessError("不存在指定记录!")
}
err = dao.UpdateOne(entity)
if err != nil {
return err
}
dao_TemplateServiceLst := dal.NewTemplateServiceLstDAO(session, user.PlantNr, user.UserId)
err = dao_TemplateServiceLst.DeleteWhere([]grmi.Predicate{meta.TemplateServiceLst_PlantNr.NewPredicate(grmi.Equal, record.PlantNr), meta.TemplateServiceLst_MainTemplateNr.NewPredicate(grmi.Equal, record.MainTemplateNr)})
if err != nil {
session.Rollback()
return err
}
//批量插入
alldata := make([]model.TemplateServiceLst, 0)
for k, v := range entity.Valst {
one := model.TemplateServiceLst{}
one.PlantNr = entity.PlantNr
one.Pos = k + 1
one.Descr = v.Descr
one.MainTemplateNr = entity.MainTemplateNr
one.MainServiceNr = utils.ValueToInt(v.MainServiceNr, 0)
one.CreateTime = entity.CreateTime
one.LastUser = entity.LastUser
one.LastModify = entity.LastModify
alldata = append(alldata, one)
}
_, err = session.Table("PM_TemplateServiceLst").Insert(&alldata)
if err != nil {
session.Rollback()
return err
}
err = session.Commit()
if err != nil {
return err
}
return nil
}
/******************************************************************************
*
* @Reference LAPP_ACURA_MOM_BACKEND/services/pm/TemplateService.Insert
*
******************************************************************************/
func (impl *TemplateServiceImplement) Insert(user *global.User, entities *[]model.Template) error {
grmi.Log(user, "/services/pm/implments/Template.service.impl.go", "InsertTemplate", "插入多个Template")
engine := db.Eloquent.Master()
session := engine.NewSession()
defer session.Close()
dao := dal.NewTemplateDAO(session, user.PlantNr, user.UserId)
for _, entity := range *entities {
record, err := dao.SelectOne(entity.MainTemplateNr)
if err != nil {
return err
}
if record != nil {
return grmi.NewBusinessError("已经存在相同主键的记录!")
}
}
err := dao.Insert(entities)
if err != nil {
return err
}
return nil
}
/******************************************************************************
*
* @Reference LAPP_ACURA_MOM_BACKEND/services/pm/TemplateService.Delete
*
******************************************************************************/
func (impl *TemplateServiceImplement) Delete(user *global.User, entities *[]model.Template) error {
grmi.Log(user, "/services/pm/implments/Template.service.impl.go", "DeleteTemplate", "删除多个Template")
engine := db.Eloquent.Master()
session := engine.NewSession()
defer session.Close()
dao := dal.NewTemplateDAO(session, user.PlantNr, user.UserId)
for _, entity := range *entities {
record, err := dao.SelectOne(entity.MainTemplateNr)
if err != nil {
return err
}
if record == nil {
return grmi.NewBusinessError("不存在指定记录!")
}
}
err := dao.Delete(entities)
if err != nil {
return err
}
return nil
}
/******************************************************************************
*
* @Reference LAPP_ACURA_MOM_BACKEND/services/pm/TemplateService.Select
*
******************************************************************************/
func (impl *TemplateServiceImplement) Select(user *global.User, urlParameters map[string]string) ([]model.Template, error) {
grmi.Log(user, "/services/pm/implments/Template.service.impl.go", "SelectTemplate", "查询Template")
condition := DefaultConditionOfTemplateAndPaging
engine := db.Eloquent.Master()
session := engine.NewSession()
defer session.Close()
predicates, err := condition.BuildPredicates(urlParameters)
if err != nil {
return nil, err
}
dao := dal.NewTemplateDAO(session, user.PlantNr, user.UserId)
result, err := dao.Select(predicates, condition.OrderByFields)
if err != nil {
return nil, err
}
return result, nil
}
func (impl *TemplateServiceImplement) SelectAll(user *global.User, urlParameters map[string]string) ([]model.Service, error) {
grmi.Log(user, "/services/pm/implments/Template.service.impl.go", "SelectAll", "SelectAll")
engine := db.Eloquent.Master()
session := engine.NewSession()
defer session.Close()
var data []model.Service
err := session.Table("Pm_Service").Where("PlantNr = ?", user.PlantNr).Find(&data)
if err != nil {
return data, err
}
return data, nil
}
/******************************************************************************
*
* @Reference LAPP_ACURA_MOM_BACKEND/services/pm/TemplateService.SelectAndPaging
*
******************************************************************************/
func (impl *TemplateServiceImplement) SelectAndPaging(user *global.User, urlParameters map[string]string) (grmi.PagingResult, error) {
grmi.Log(user, "/services/pm/implments/Template.service.impl.go", "SelectTemplate", "查询Template")
condition := DefaultConditionOfTemplateAndPaging
engine := db.Eloquent.Master()
session := engine.NewSession()
defer session.Close()
predicates, err := condition.BuildPredicates(urlParameters)
if err != nil {
return grmi.EmptyPagingResult, err
}
dao := dal.NewTemplateDAO(session, user.PlantNr, user.UserId)
condition.Fill(urlParameters)
result, err := dao.SelectAndPaging(condition.Paging, predicates, condition.OrderByFields)
if err != nil {
return grmi.EmptyPagingResult, err
}
return result, nil
}
/******************************************************************************
*
* @Reference LAPP_ACURA_MOM_BACKEND/services/pm/TemplateService.Update
*
******************************************************************************/
func (impl *TemplateServiceImplement) Update(user *global.User, entities *[]model.Template) error {
grmi.Log(user, "/services/pm/implments/Template.service.impl.go", "UpdateTemplate", "修改多个Template")
engine := db.Eloquent.Master()
session := engine.NewSession()
defer session.Close()
dao := dal.NewTemplateDAO(session, user.PlantNr, user.UserId)
for _, entity := range *entities {
record, err := dao.SelectOne(entity.MainTemplateNr)
if err != nil {
return err
}
if record == nil {
return grmi.NewBusinessError("不存在指定记录!")
}
}
err := dao.Update(entities)
if err != nil {
return err
}
return nil
}