feat:增加用户企业管理信息
This commit is contained in:
102
app/api/enterprise/api/manage.go
Normal file
102
app/api/enterprise/api/manage.go
Normal file
@ -0,0 +1,102 @@
|
||||
package api
|
||||
|
||||
import (
|
||||
"SciencesServer/app/api/enterprise/controller/manage"
|
||||
"SciencesServer/app/basic/api"
|
||||
"SciencesServer/app/session"
|
||||
"github.com/gin-gonic/gin"
|
||||
)
|
||||
|
||||
type Manage struct{}
|
||||
|
||||
type (
|
||||
// enterpriseForm 企业信息
|
||||
enterpriseForm struct {
|
||||
Mode int `json:"mode" form:"mode" binding:"required"`
|
||||
Title string `json:"title" form:"title" binding:"required"`
|
||||
Name string `json:"name" form:"name"`
|
||||
Mobile string `json:"mobile" form:"mobile"`
|
||||
Content string `json:"content" form:"content"`
|
||||
Papers []string `json:"papers" form:"papers"`
|
||||
Patents []string `json:"patents" form:"patents"`
|
||||
}
|
||||
)
|
||||
|
||||
func (a *enterpriseForm) paperInfo() []uint64 {
|
||||
out := make([]uint64, 0)
|
||||
obj := new(api.IDStringForm)
|
||||
|
||||
for _, v := range a.Papers {
|
||||
obj.ID = v
|
||||
out = append(out, obj.Convert())
|
||||
}
|
||||
return out
|
||||
}
|
||||
|
||||
func (a *enterpriseForm) PatentInfo() []uint64 {
|
||||
out := make([]uint64, 0)
|
||||
obj := new(api.IDStringForm)
|
||||
|
||||
for _, v := range a.Patents {
|
||||
obj.ID = v
|
||||
out = append(out, obj.Convert())
|
||||
}
|
||||
return out
|
||||
}
|
||||
|
||||
func (*Manage) Enterprise(c *gin.Context) {
|
||||
form := &struct {
|
||||
Mode int `json:"mode" form:"mode" binding:"required"`
|
||||
Title string `json:"title" form:"title"`
|
||||
api.PageForm
|
||||
}{}
|
||||
if err := api.Bind(form)(c); err != nil {
|
||||
api.APIFailure(err.(error))(c)
|
||||
return
|
||||
}
|
||||
data, err := manage.NewEnterprise()(api.GetSession()(c).(*session.Enterprise), api.GetLocal()(c).(string)).
|
||||
List(form.Mode, form.Title, form.Page, form.PageSize)
|
||||
api.APIResponse(err, data)(c)
|
||||
}
|
||||
|
||||
func (*Manage) EnterpriseAdd(c *gin.Context) {
|
||||
form := new(enterpriseForm)
|
||||
|
||||
if err := api.Bind(form)(c); err != nil {
|
||||
api.APIFailure(err.(error))(c)
|
||||
return
|
||||
}
|
||||
err := manage.NewEnterprise()(api.GetSession()(c).(*session.Enterprise), api.GetLocal()(c).(string)).
|
||||
Form(&manage.EnterpriseParams{Mode: form.Mode, Title: form.Title, Name: form.Name, Mobile: form.Mobile,
|
||||
Papers: form.paperInfo(), Patents: form.PatentInfo(), Content: form.Content,
|
||||
})
|
||||
api.APIResponse(err)(c)
|
||||
}
|
||||
|
||||
func (*Manage) EnterpriseEdit(c *gin.Context) {
|
||||
form := &struct {
|
||||
api.IDStringForm
|
||||
enterpriseForm
|
||||
}{}
|
||||
if err := api.Bind(form)(c); err != nil {
|
||||
api.APIFailure(err.(error))(c)
|
||||
return
|
||||
}
|
||||
err := manage.NewEnterprise()(api.GetSession()(c).(*session.Enterprise), api.GetLocal()(c).(string)).
|
||||
Form(&manage.EnterpriseParams{ID: form.Convert(), Mode: form.Mode, Title: form.Title, Name: form.Name,
|
||||
Mobile: form.Mobile, Papers: form.paperInfo(), Patents: form.PatentInfo(), Content: form.Content,
|
||||
})
|
||||
api.APIResponse(err)(c)
|
||||
}
|
||||
|
||||
func (*Manage) EnterpriseDelete(c *gin.Context) {
|
||||
form := new(api.IDStringForm)
|
||||
|
||||
if err := api.Bind(form)(c); err != nil {
|
||||
api.APIFailure(err.(error))(c)
|
||||
return
|
||||
}
|
||||
err := manage.NewEnterprise()(api.GetSession()(c).(*session.Enterprise), api.GetLocal()(c).(string)).
|
||||
Delete(form.Convert())
|
||||
api.APIResponse(err)(c)
|
||||
}
|
126
app/api/enterprise/controller/manage/enterprise.go
Normal file
126
app/api/enterprise/controller/manage/enterprise.go
Normal 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}
|
||||
}
|
||||
}
|
@ -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("无权限操作")
|
||||
}
|
||||
|
@ -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 &&
|
||||
|
@ -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
|
||||
|
11
app/api/enterprise/model/manage_enterprise.go
Normal file
11
app/api/enterprise/model/manage_enterprise.go
Normal file
@ -0,0 +1,11 @@
|
||||
package model
|
||||
|
||||
import "SciencesServer/app/common/model"
|
||||
|
||||
type ManageEnterprise struct {
|
||||
*model.ManageEnterprise
|
||||
}
|
||||
|
||||
func NewManageEnterprise() *ManageEnterprise {
|
||||
return &ManageEnterprise{model.NewManageEnterprise()}
|
||||
}
|
45
app/api/enterprise/model/user_cooperate_enterprise.go
Normal file
45
app/api/enterprise/model/user_cooperate_enterprise.go
Normal file
@ -0,0 +1,45 @@
|
||||
package model
|
||||
|
||||
import (
|
||||
"SciencesServer/app/common/model"
|
||||
"SciencesServer/serve/orm"
|
||||
)
|
||||
|
||||
type UserCooperateEnterprise struct {
|
||||
*model.UserCooperateEnterprise
|
||||
}
|
||||
|
||||
// UserCooperateEnterpriseInfo 用户企业关联信息
|
||||
type UserCooperateEnterpriseInfo struct {
|
||||
*model.UserCooperateEnterprise
|
||||
PaperTitle string `json:"paper_title"`
|
||||
PatentTitle string `json:"patent_title"`
|
||||
}
|
||||
|
||||
// Enterprise 企业信息
|
||||
func (m *UserCooperateEnterprise) Enterprise(page, pageSize int, count *int64, where ...*model.ModelWhere) ([]*UserCooperateEnterpriseInfo, error) {
|
||||
db := orm.GetDB().Table(m.TableName()+" AS u").
|
||||
Select("u.*",
|
||||
"(SELECT GROUP_CONCAT(t_p.title) FROM (SELECT id, title FROM technology_paper) AS t_p WHERE FIND_IN_SET(t_p.id, u.paper)) AS paper_title",
|
||||
"(SELECT GROUP_CONCAT(s_p.title) FROM (SELECT id, title FROM sys_patent) AS s_p WHERE FIND_IN_SET(s_p.id, u.patent)) AS patent_title").
|
||||
Where("u.is_deleted = ?", model.DeleteStatusForNot)
|
||||
|
||||
out := make([]*UserCooperateEnterpriseInfo, 0)
|
||||
|
||||
if len(where) > 0 {
|
||||
for _, v := range where {
|
||||
db = db.Where(v.Condition, v.Value)
|
||||
}
|
||||
}
|
||||
if err := db.Count(count).Error; err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if err := db.Order("u.id " + model.OrderModeToDesc).Offset((page - 1) * pageSize).Limit(pageSize).Scan(&out).Error; err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return out, nil
|
||||
}
|
||||
|
||||
func NewUserCooperateEnterprise() *UserCooperateEnterprise {
|
||||
return &UserCooperateEnterprise{model.NewUserCooperateEnterprise()}
|
||||
}
|
Reference in New Issue
Block a user