feat:完善信息
This commit is contained in:
@ -89,6 +89,12 @@ type (
|
|||||||
Kind int `json:"kind" form:"kind" binding:"required"`
|
Kind int `json:"kind" form:"kind" binding:"required"`
|
||||||
Keywords []string `json:"keywords" form:"keywords"`
|
Keywords []string `json:"keywords" form:"keywords"`
|
||||||
}
|
}
|
||||||
|
// equipmentForm 设备参数
|
||||||
|
equipmentForm struct {
|
||||||
|
Title string `json:"title" form:"title" binding:"required"`
|
||||||
|
Research string `json:"research" form:"research" binding:"required"`
|
||||||
|
Describe string `json:"describe" form:"describe"`
|
||||||
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
func (a *instanceForm) FilterProveImages() string {
|
func (a *instanceForm) FilterProveImages() string {
|
||||||
@ -451,3 +457,55 @@ func (a *Technology) TopicDelete(c *gin.Context) {
|
|||||||
Delete(form.Convert())
|
Delete(form.Convert())
|
||||||
api.APIResponse(err)(c)
|
api.APIResponse(err)(c)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (a *Technology) Equipment(c *gin.Context) {
|
||||||
|
form := &struct {
|
||||||
|
Title string `json:"title" form:"title"`
|
||||||
|
api.PageForm
|
||||||
|
}{}
|
||||||
|
if err := api.Bind(form)(c); err != nil {
|
||||||
|
api.APIFailure(err.(error))(c)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
data, err := technology2.NewEquipment()(api.GetSession()(c).(*service.SessionEnterprise), api.GetLocal()(c).(string)).
|
||||||
|
List(form.Title, form.Page, form.PageSize)
|
||||||
|
api.APIResponse(err, data)(c)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *Technology) EquipmentAdd(c *gin.Context) {
|
||||||
|
form := new(equipmentForm)
|
||||||
|
|
||||||
|
if err := api.Bind(form)(c); err != nil {
|
||||||
|
api.APIFailure(err.(error))(c)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
err := technology2.NewEquipment()(api.GetSession()(c).(*service.SessionEnterprise), api.GetLocal()(c).(string)).
|
||||||
|
Form(&technology2.EquipmentParams{Title: form.Title, Research: form.Research, Describe: form.Describe})
|
||||||
|
api.APIResponse(err)(c)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *Technology) EquipmentEdit(c *gin.Context) {
|
||||||
|
form := &struct {
|
||||||
|
api.IDStringForm
|
||||||
|
equipmentForm
|
||||||
|
}{}
|
||||||
|
if err := api.Bind(form)(c); err != nil {
|
||||||
|
api.APIFailure(err.(error))(c)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
err := technology2.NewEquipment()(api.GetSession()(c).(*service.SessionEnterprise), api.GetLocal()(c).(string)).
|
||||||
|
Form(&technology2.EquipmentParams{ID: form.Convert(), Title: form.Title, Research: form.Research, Describe: form.Describe})
|
||||||
|
api.APIResponse(err)(c)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *Technology) EquipmentDelete(c *gin.Context) {
|
||||||
|
form := new(api.IDStringForm)
|
||||||
|
|
||||||
|
if err := api.Bind(form)(c); err != nil {
|
||||||
|
api.APIFailure(err.(error))(c)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
err := technology2.NewEquipment()(api.GetSession()(c).(*service.SessionEnterprise), api.GetLocal()(c).(string)).
|
||||||
|
Delete(form.Convert())
|
||||||
|
api.APIResponse(err)(c)
|
||||||
|
}
|
||||||
|
111
app/api/enterprise/controller/technology/equipment.go
Normal file
111
app/api/enterprise/controller/technology/equipment.go
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
package technology
|
||||||
|
|
||||||
|
import (
|
||||||
|
"SciencesServer/app/api/enterprise/model"
|
||||||
|
"SciencesServer/app/api/manage/controller"
|
||||||
|
model2 "SciencesServer/app/common/model"
|
||||||
|
"SciencesServer/app/service"
|
||||||
|
"errors"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Equipment struct {
|
||||||
|
*service.SessionEnterprise
|
||||||
|
local string
|
||||||
|
}
|
||||||
|
|
||||||
|
type EquipmentHandle func(enterprise *service.SessionEnterprise, local string) *Equipment
|
||||||
|
|
||||||
|
type EquipmentParams struct {
|
||||||
|
ID uint64
|
||||||
|
Title, Research, Describe string
|
||||||
|
}
|
||||||
|
|
||||||
|
type EquipmentInfo struct {
|
||||||
|
ID string `json:"id"`
|
||||||
|
*model2.TechnologyEquipment
|
||||||
|
}
|
||||||
|
|
||||||
|
// List 列表信息
|
||||||
|
func (c *Equipment) List(title string, page, pageSize int) (*controller.ReturnPages, error) {
|
||||||
|
mTechnologyEquipment := model.NewTechnologyEquipment()
|
||||||
|
|
||||||
|
where := []*model2.ModelWhereOrder{&model2.ModelWhereOrder{
|
||||||
|
Where: model2.NewWhere("tenant_id", c.TenantID),
|
||||||
|
Order: model2.NewOrder("id", model2.OrderModeToDesc),
|
||||||
|
}, &model2.ModelWhereOrder{
|
||||||
|
Where: model2.NewWhere("local", c.local),
|
||||||
|
}}
|
||||||
|
|
||||||
|
if title != "" {
|
||||||
|
where = append(where, &model2.ModelWhereOrder{
|
||||||
|
Where: model2.NewWhereLike("title", title),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
out := make([]*model2.TechnologyEquipment, 0)
|
||||||
|
|
||||||
|
var count int64
|
||||||
|
|
||||||
|
if err := model2.Pages(mTechnologyEquipment.TechnologyEquipment, &out, page, pageSize, &count, where...); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
list := make([]*EquipmentInfo, 0)
|
||||||
|
|
||||||
|
for _, v := range out {
|
||||||
|
list = append(list, &EquipmentInfo{
|
||||||
|
ID: v.GetEncodeID(), TechnologyEquipment: v,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
return &controller.ReturnPages{Data: list, Count: count}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Equipment) Form(params *EquipmentParams) error {
|
||||||
|
mTechnologyEquipment := model.NewTechnologyEquipment()
|
||||||
|
|
||||||
|
if params.ID > 0 {
|
||||||
|
mTechnologyEquipment.ID = params.ID
|
||||||
|
|
||||||
|
isExist, err := model2.First(mTechnologyEquipment.TechnologyEquipment)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
} else if !isExist {
|
||||||
|
return errors.New("操作错误,设备信息不存在")
|
||||||
|
} else if mTechnologyEquipment.Local.Local != c.local {
|
||||||
|
return errors.New("无权限操作")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
mTechnologyEquipment.Title = params.Title
|
||||||
|
mTechnologyEquipment.Research = params.Research
|
||||||
|
mTechnologyEquipment.Describe = params.Describe
|
||||||
|
|
||||||
|
if mTechnologyEquipment.ID > 0 {
|
||||||
|
return model2.Updates(mTechnologyEquipment.TechnologyEquipment, mTechnologyEquipment.TechnologyEquipment)
|
||||||
|
}
|
||||||
|
return model2.Create(mTechnologyEquipment.TechnologyEquipment)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Delete 删除操作
|
||||||
|
func (c *Equipment) Delete(id uint64) error {
|
||||||
|
mTechnologyEquipment := model.NewTechnologyEquipment()
|
||||||
|
mTechnologyEquipment.ID = id
|
||||||
|
|
||||||
|
isExist, err := model2.First(mTechnologyEquipment.TechnologyEquipment)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
} else if !isExist {
|
||||||
|
return errors.New("操作错误,设备信息不存在")
|
||||||
|
} else if mTechnologyEquipment.Local.Local != c.local {
|
||||||
|
return errors.New("无权限操作")
|
||||||
|
}
|
||||||
|
return model2.Delete(mTechnologyEquipment.TechnologyEquipment)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewEquipment() EquipmentHandle {
|
||||||
|
return func(enterprise *service.SessionEnterprise, local string) *Equipment {
|
||||||
|
return &Equipment{
|
||||||
|
SessionEnterprise: enterprise,
|
||||||
|
local: local,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
11
app/api/enterprise/model/technology_equipment.go
Normal file
11
app/api/enterprise/model/technology_equipment.go
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
package model
|
||||||
|
|
||||||
|
import "SciencesServer/app/common/model"
|
||||||
|
|
||||||
|
type TechnologyEquipment struct {
|
||||||
|
*model.TechnologyEquipment
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewTechnologyEquipment() *TechnologyEquipment {
|
||||||
|
return &TechnologyEquipment{model.NewTechnologyEquipment()}
|
||||||
|
}
|
21
app/common/model/technology_equipment.go
Normal file
21
app/common/model/technology_equipment.go
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
package model
|
||||||
|
|
||||||
|
// TechnologyEquipment 技术设备管理信息
|
||||||
|
type TechnologyEquipment struct {
|
||||||
|
Model
|
||||||
|
ModelTenant
|
||||||
|
Local
|
||||||
|
Title string `gorm:"column:title;type:varchar(30);default:null;comment:名称" json:"title"`
|
||||||
|
Research string `gorm:"column:research;type:varchar(255);default:null;comment:研究信息" json:"research"`
|
||||||
|
Describe string `gorm:"column:describe;type:varchar(255);default:null;comment:描述" json:"describe"`
|
||||||
|
ModelDeleted
|
||||||
|
ModelAt
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *TechnologyEquipment) TableName() string {
|
||||||
|
return m.NewTableName("technology_equipment")
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewTechnologyEquipment() *TechnologyEquipment {
|
||||||
|
return &TechnologyEquipment{}
|
||||||
|
}
|
@ -146,5 +146,9 @@ func registerEnterpriseAPI(app *gin.Engine) {
|
|||||||
technology.POST("/topic/add", _api.TopicAdd)
|
technology.POST("/topic/add", _api.TopicAdd)
|
||||||
technology.POST("/topic/edit", _api.TopicEdit)
|
technology.POST("/topic/edit", _api.TopicEdit)
|
||||||
technology.POST("/topic/delete", _api.TopicDelete)
|
technology.POST("/topic/delete", _api.TopicDelete)
|
||||||
|
technology.POST("/equipment", _api.Equipment)
|
||||||
|
technology.POST("/equipment/add", _api.EquipmentAdd)
|
||||||
|
technology.POST("/equipment/edit", _api.EquipmentEdit)
|
||||||
|
technology.POST("/equipment/delete", _api.EquipmentDelete)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user