feat:增加用户企业管理信息

This commit is contained in:
henry
2021-11-30 16:09:04 +08:00
parent c6f0129e4b
commit 5bab79a613
13 changed files with 403 additions and 13 deletions

View File

@ -0,0 +1,126 @@
package manage
import (
"SciencesServer/app/api/enterprise/model"
"SciencesServer/app/basic/controller"
model2 "SciencesServer/app/common/model"
"SciencesServer/app/session"
"errors"
)
// Enterprise 企业管理信息
type Enterprise struct {
*session.Enterprise
local string
}
type EnterpriseHandle func(session *session.Enterprise, local string) *Enterprise
type (
// EnterpriseInfo 企业信息
EnterpriseInfo struct {
ID string `json:"id"`
*model.UserCooperateEnterpriseInfo
Papers []string `json:"papers"`
Patents []string `json:"patents"`
}
// EnterpriseParams 企业参数信息
EnterpriseParams struct {
ID uint64
Mode int
Title, Name, Mobile string
Papers, Patents []uint64
Content string
}
)
// List 列表信息
func (c *Enterprise) List(mode int, title string, page, pageSize int) (*controller.ReturnPages, error) {
mUserCooperateEnterprise := model.NewUserCooperateEnterprise()
where := []*model2.ModelWhere{
model2.NewWhere("mode", mode),
model2.NewWhere("local", c.local),
model2.NewWhere("uid", c.UID),
}
if title != "" {
where = append(where, model2.NewWhereLike("title", title))
}
var count int64
out, err := mUserCooperateEnterprise.Enterprise(page, pageSize, &count, where...)
if err != nil {
return nil, err
}
list := make([]*EnterpriseInfo, 0)
for _, v := range out {
list = append(list, &EnterpriseInfo{
ID: v.GetEncodeID(),
UserCooperateEnterpriseInfo: v,
Papers: v.GetPaperAttribute(),
Patents: v.GetPatentAttribute(),
})
}
return &controller.ReturnPages{Data: list, Count: count}, nil
}
// Form 数据操作
func (c *Enterprise) Form(params *EnterpriseParams) error {
mUserCooperateEnterprise := model.NewUserCooperateEnterprise()
if params.ID > 0 {
mUserCooperateEnterprise.ID = params.ID
isExist, err := model2.FirstField(mUserCooperateEnterprise.UserCooperateEnterprise, []string{"id", "uid", "created_at"})
if err != nil {
return err
} else if !isExist {
return errors.New("操作错误,企业信息不存在或已被删除")
} else if mUserCooperateEnterprise.UID != c.UID {
return errors.New("无权限操作")
}
}
mUserCooperateEnterprise.Title = params.Title
mUserCooperateEnterprise.Mode = model2.UserCooperateEnterpriseMode(params.Mode)
// 已合作信息
if mUserCooperateEnterprise.Mode == model2.UserCooperateEnterpriseModeForCooperateAlready {
mUserCooperateEnterprise.SetPaperAttribute(params.Papers)
mUserCooperateEnterprise.SetPatentAttribute(params.Patents)
// 想合作信息
} else if mUserCooperateEnterprise.Mode == model2.UserCooperateEnterpriseModeForCooperateToWant {
mUserCooperateEnterprise.Name = params.Name
mUserCooperateEnterprise.Mobile = params.Mobile
mUserCooperateEnterprise.Content = params.Content
}
if mUserCooperateEnterprise.ID > 0 {
return model2.Updates(mUserCooperateEnterprise.UserCooperateEnterprise, mUserCooperateEnterprise.UserCooperateEnterprise)
}
return model2.Create(mUserCooperateEnterprise.UserCooperateEnterprise)
}
// Delete 删除操作
func (c *Enterprise) Delete(id uint64) error {
mUserCooperateEnterprise := model.NewUserCooperateEnterprise()
mUserCooperateEnterprise.ID = id
isExist, err := model2.FirstField(mUserCooperateEnterprise.UserCooperateEnterprise, []string{"id", "uid", "created_at"})
if err != nil {
return err
} else if !isExist {
return errors.New("操作错误,企业信息不存在或已被删除")
} else if mUserCooperateEnterprise.UID != c.UID {
return errors.New("无权限操作")
}
return model2.Delete(mUserCooperateEnterprise.UserCooperateEnterprise)
}
func NewEnterprise() EnterpriseHandle {
return func(session *session.Enterprise, local string) *Enterprise {
return &Enterprise{Enterprise: session, local: local}
}
}

View File

@ -77,7 +77,7 @@ func (c *Demand) Detail(id uint64) (*DemandInfo, error) {
if err != nil {
return nil, err
} else if !isExist {
return nil, errors.New("操作错误,需求信息不存在或已删除")
return nil, errors.New("操作错误,需求信息不存在或已删除")
} else if mServiceDemand.UID != c.UID {
return nil, errors.New("无权限操作")
}
@ -98,7 +98,7 @@ func (c *Demand) Form(params *DemandParams) error {
if isExist, err := model2.FirstField(mServiceDemand.ServiceDemand, []string{"id", "uid", "status", "created_at"}); err != nil {
return err
} else if !isExist {
return errors.New("操作错误,需求信息不存在或已删除")
return errors.New("操作错误,需求信息不存在或已删除")
} else if mServiceDemand.UID != c.UID {
return errors.New("无权限操作")
} else if mServiceDemand.Status != model2.ServiceDemandStatusForDraft {
@ -133,7 +133,7 @@ func (c *Demand) Delete(id uint64) error {
if isExist, err := model2.FirstField(mServiceDemand.ServiceDemand, []string{"id", "uid"}); err != nil {
return err
} else if !isExist {
return errors.New("操作错误,需求信息不存在或已删除")
return errors.New("操作错误,需求信息不存在或已删除")
} else if mServiceDemand.UID != c.UID {
return errors.New("无权限操作")
}

View File

@ -116,7 +116,7 @@ func (c *Demand) Form(params *DemandParams) error {
if err != nil {
return err
} else if !isExist {
return errors.New("操作错误,需求信息不存在或已删除")
return errors.New("操作错误,需求信息不存在或已删除")
} else if mTechnologyDemand.UID != c.UID {
return errors.New("无权限操作")
} else if mTechnologyDemand.Status != model2.TechnologyDemandStatusForRefuse &&

View File

@ -70,7 +70,7 @@ func (c *Paper) Form(params *PaperParams) error {
return err
} else if !isExist {
return errors.New("当前论文信息不存在")
} else if mTechnologyPaper.MUid != c.ManageUID {
} else if mTechnologyPaper.UID != c.UID {
return errors.New("无权限操作")
}
}
@ -83,8 +83,7 @@ func (c *Paper) Form(params *PaperParams) error {
mTechnologyPaper.Remark = params.Remark
if params.ID <= 0 {
mTechnologyPaper.TenantID = c.TenantID
mTechnologyPaper.MUid = c.ManageUID
mTechnologyPaper.UID = c.UID
mTechnologyPaper.Local.Local = c.local
return model2.Create(mTechnologyPaper.TechnologyPaper)
}
@ -104,7 +103,7 @@ func (c *Paper) Delete(id uint64) error {
if err != nil {
return err
} else if count <= 0 {
return errors.New("当前论文信息不存在")
return errors.New("操作错误,当前论文信息不存在或已被删除")
}
if err = model2.Delete(mTechnologyPaper.TechnologyPaper); err != nil {
return err