@ -6,11 +6,10 @@ import (
"SciencesServer/app/basic/controller"
model2 "SciencesServer/app/common/model"
"SciencesServer/app/session"
"SciencesServer/serve/orm"
"SciencesServer/utils"
"errors"
"fmt"
"gorm.io/gorm "
"time "
)
// Patent 专利信息
@ -30,7 +29,7 @@ type (
// PatentDetailInfo 专利详细信息
PatentDetailInfo struct {
ID string ` json:"id" `
* model2 . Sys Patent
* model2 . Technology Patent
}
// PatentParams 专利参数信息
PatentParams struct {
@ -57,7 +56,7 @@ type (
}
)
func ( c * Patent ) ipcTree ( src [ ] * model2 . Sys PatentClassify, parentID uint64 ) [ ] * PatentIPCInfo {
func ( c * Patent ) ipcTree ( src [ ] * model2 . Technology PatentClassify, parentID uint64 ) [ ] * PatentIPCInfo {
out := make ( [ ] * PatentIPCInfo , 0 )
for _ , v := range src {
@ -79,7 +78,7 @@ func (c *Patent) ipcTree(src []*model2.SysPatentClassify, parentID uint64) []*Pa
return out
}
func ( c * PatentParams ) checkParams ( iModel * model . Sys Patent, condition map [ string ] interface { } ) error {
func ( c * PatentParams ) checkParams ( iModel * model . Technology Patent, condition map [ string ] interface { } ) error {
isExist , err := iModel . IsExistParams ( condition )
if err != nil {
@ -92,10 +91,17 @@ func (c *PatentParams) checkParams(iModel *model.SysPatent, condition map[string
// Instance 首页信息
func ( c * Patent ) Instance ( tenantID uint64 , title , ipc string , page , pageSize int ) ( * controller . ReturnPages , error ) {
mSysPatent := model . NewSys Patent ( )
mSysPatent := model . NewTechnology Patent ( )
where := make ( [ ] * model2 . ModelWhere , 0 )
if c . TenantID > 0 {
where = append ( where , model2 . NewWhere ( "p.tenant_id" , c . TenantID ) )
}
if tenantID > 0 {
where = append ( where , model2 . NewWhere ( "p.tenant_id" , tenantID ) )
}
if title != "" {
where = append ( where , model2 . NewWhereLike ( "p.title" , title ) )
}
@ -123,140 +129,152 @@ func (c *Patent) Instance(tenantID uint64, title, ipc string, page, pageSize int
// Detail 详细信息
func ( c * Patent ) Detail ( id uint64 ) ( * PatentDetailInfo , error ) {
mSys Patent := model . NewSys Patent ( )
mSys Patent . ID = id
mTechnology Patent := model . NewTechnology Patent ( )
mTechnology Patent . ID = id
isExist , err := model2 . First ( mSys Patent . Sys Patent)
isExist , err := model2 . First ( mTechnology Patent . Technology Patent)
if err != nil {
return nil , err
} else if ! isExist {
return nil , errors . New ( "操作错误,专利信息不存在或已被删除" )
}
return & PatentDetailInfo { ID : mSys Patent . GetEncodeID ( ) , SysPatent : mSysPatent . SysPatent } , nil
return & PatentDetailInfo { ID : mTechnology Patent . GetEncodeID ( ) ,
TechnologyPatent : mTechnologyPatent . TechnologyPatent } , nil
}
// Form 数据操作
func ( c * Patent ) Form ( params * PatentParams ) error {
mSys Patent := model . NewSys Patent ( )
mTechnology Patent := model . NewTechnology Patent ( )
_condition := make ( map [ string ] interface { } , 0 )
if params . ID > 0 {
mSys Patent . ID = params . ID
mTechnology Patent . ID = params . ID
isExist , err := model2 . FirstField ( mSys Patent . Sys Patent, [ ] string { "id" , "tenant_id" , "apply_code" , "ipc_code" , "created_at" } )
isExist , err := model2 . FirstField ( mTechnology Patent . Technology Patent, [ ] string { "id" , "tenant_id" , "uid" , "apply_code" , "ipc_code" , "created_at" } )
if err != nil {
return err
} else if ! isExist {
return errors . New ( "操作错误,专利信息不存在或已被删除" )
} else if c . TenantID > 0 && mTechnologyPatent . TenantID > 0 && c . TenantID != mTechnologyPatent . TenantID {
return errors . New ( "操作错误,无权限操作" )
}
if mSys Patent . ApplyCode != params . ApplyCode {
if mTechnology Patent . ApplyCode != params . ApplyCode {
_condition [ "apply_code" ] = params . ApplyCode
}
if mSys Patent . IPCCode != params . IPCCode {
if mTechnology Patent . IPCCode != params . IPCCode {
_condition [ "ipc_code" ] = params . IPCCode
}
if len ( _condition ) > 0 {
if isExist , err = mSys Patent . IsExistParams ( _condition ) ; err != nil {
if isExist , err = mTechnology Patent . IsExistParams ( _condition ) ; err != nil {
return err
} else if isExist {
return errors . New ( "操作错误,申请号或公开(公告)号已存在" )
}
}
}
mSys Patent . Kind = model2 . SysParentKind ( params . Kind )
mSys Patent . Title = params . Title
mSys Patent . FileUrl = params . FileUrl
mSys Patent . ApplyCode = params . ApplyCode
mSys Patent . ApplyAt = params . ApplyAt
mSys Patent . OpenCode = params . OpenCode
mSys Patent . OpenAt = params . OpenAt
mSys Patent . ApplyName = params . ApplyName
mSys Patent . ApplyAddress = params . ApplyAddress
mSys Patent . Inventor = params . Inventor
mSys Patent . Description = params . Description
mSys Patent . PrincipalClaim = params . PrincipalClaim
mSys Patent . IPCCode = params . IPCCode
mSys Patent . ShelfStatus = model2 . ShelfStatusKind ( params . ShelfStatus )
mSys Patent . Status = model2 . SysParentStatus ( params . Status )
mTechnology Patent . Kind = model2 . SysParentKind ( params . Kind )
mTechnology Patent . Title = params . Title
mTechnology Patent . FileUrl = params . FileUrl
mTechnology Patent . ApplyCode = params . ApplyCode
mTechnology Patent . ApplyAt = params . ApplyAt
mTechnology Patent . OpenCode = params . OpenCode
mTechnology Patent . OpenAt = params . OpenAt
mTechnology Patent . ApplyName = params . ApplyName
mTechnology Patent . ApplyAddress = params . ApplyAddress
mTechnology Patent . Inventor = params . Inventor
mTechnology Patent . Description = params . Description
mTechnology Patent . PrincipalClaim = params . PrincipalClaim
mTechnology Patent . IPCCode = params . IPCCode
mTechnology Patent . ShelfStatus = model2 . ShelfStatusKind ( params . ShelfStatus )
mTechnology Patent . Status = model2 . SysParentStatus ( params . Status )
if mSys Patent . ID > 0 {
return model2 . Updates ( mSys Patent . Sys Patent, mSys Patent . Sys Patent)
if mTechnology Patent . ID > 0 {
return model2 . Updates ( mTechnology Patent . Technology Patent, mTechnology Patent . Technology Patent)
}
_condition [ "apply_code" ] = params . ApplyCode
_condition [ "ipc_code" ] = params . IPCCode
if isExist , err := mSys Patent . IsExistParams ( _condition ) ; err != nil {
if isExist , err := mTechnology Patent . IsExistParams ( _condition ) ; err != nil {
return err
} else if isExist {
return errors . New ( "操作错误,申请号或公开(公告)号已存在" )
}
return model2 . Create ( mSysPatent . SysPatent )
mTechnologyPatent . TenantID = c . TenantID
return model2 . Create ( mTechnologyPatent . TechnologyPatent )
}
// Bind 绑定信息
func ( c * Patent ) Bind ( id , uid uint64 ) error {
mSys Patent := model . NewSys Patent ( )
mSys Patent . ID = id
mTechnology Patent := model . NewTechnology Patent ( )
mTechnology Patent . ID = id
isExist , err := model2 . FirstField ( mSys Patent . Sys Patent, [ ] string { "id" , "tenant_id" } )
isExist , err := model2 . FirstField ( mTechnology Patent . Technology Patent, [ ] string { "id" , "uid" , "tenant_id" } )
if err != nil {
return err
} else if ! isExist {
return errors . New ( "操作错误,专利信息不存在或已被删除" )
} else if c . TenantID > 0 && mTechnologyPatent . TenantID > 0 && c . TenantID != mTechnologyPatent . TenantID {
return errors . New ( "操作错误,无权限操作" )
}
mUserPatent : = model . NewUserPatent ( )
if isExist , err = model2 . FirstField ( mUserPatent . UserPatent , [ ] string { "id" , "uid" } , model2 . NewWhere ( "patent_id" , id ) ) ; err != nil {
if err = model2 . Updates ( mTechnologyPatent . TechnologyPatent , map [ string ] interface { } {
"uid" : uid , "updated_at" : time . Now ( ) ,
} ) ; err != nil {
return err
} else if ! isExist {
mUserPatent . UID = uid
mUserPatent . PatentID = id
return model2 . Create ( mUserPatent . UserPatent )
}
if mUserPatent . UID == uid {
return nil
}
return orm . GetDB ( ) . Transaction ( func ( tx * gorm . DB ) error {
if err = model2 . DeleteWhere ( mUserPatent . UserPatent , [ ] * model2 . ModelWhere { model2 . NewWhere ( "patent_id" , id ) } ) ; err != nil {
return err
}
mUserPatent. UID = u id
mUserPatent. PatentID = id
return model2 . Create ( mUserPatent . UserPatent , tx )
} )
return nil
//mUserPatent := model.NewUserPatent()
//if isExist, err = model2.FirstField(mUserPatent.UserPatent, []string{"id", "uid"}, model2.NewWhere("patent_id", id)); err != nil {
// return err
//} else if !isExist {
// mUserPatent.UID = uid
// mUserPatent.PatentID = id
// return model2.Create( mUserPatent.User Patent)
//}
//if mUserPatent.UID == uid {
// return nil
//}
//return orm.GetDB().Transaction(func(tx *gorm.DB) error {
// if err = model2.DeleteWhere(mUserPatent.UserPatent, []*model2.ModelWhere{model2.NewWhere("patent_id", id)}); err != nil {
// return err
// }
// mUserPatent.UID = uid
// mUserPatent.PatentID = id
// return model2.Create(mUserPatent.UserPatent, tx)
//})
}
func ( c * Patent ) Shelf ( id uint64 ) error {
return controller . NewShelf ( controller . WithShelfSessionAdmin ( c . Admin ) ) . Handle ( model2 . NewSys Patent ( ) , id )
return controller . NewShelf ( controller . WithShelfSessionAdmin ( c . Admin ) ) . Handle ( model2 . NewTechnology Patent ( ) , id )
}
// Delete 删除操作
func ( c * Patent ) Delete ( id uint64 ) error {
mSys Patent := model . NewSys Patent ( )
mSys Patent . ID = id
mTechnology Patent := model . NewTechnology Patent ( )
mTechnology Patent . ID = id
isExist , err := model2 . FirstField ( mSys Patent . Sys Patent, [ ] string { "id" , "tenant_id" } )
isExist , err := model2 . FirstField ( mTechnology Patent . Technology Patent, [ ] string { "id" , "uid" , "tenant_id" } )
if err != nil {
return err
} else if ! isExist {
return errors . New ( "操作错误,专利信息不存在或已被删除" )
} else if c . TenantID > 0 && mSys Patent . TenantID != c . TenantID {
} else if c . TenantID > 0 && mTechnology Patent . TenantID > 0 && c . TenantID != mTechnologyPatent . TenantID {
return errors . New ( "操作错误,无权限操作" )
}
return model2 . Delete ( mSys Patent . Sys Patent)
return model2 . Delete ( mTechnology Patent . Technology Patent)
}
// IPC IPC信息
func ( c * Patent ) IPC ( ) ( [ ] * PatentIPCInfo , error ) {
mSys PatentClassify := model . NewSys PatentClassify ( )
out := make ( [ ] * model2 . Sys PatentClassify, 0 )
mTechnology PatentClassify := model . NewTechnology PatentClassify ( )
out := make ( [ ] * model2 . Technology PatentClassify, 0 )
if err := model2 . Scan ( mSys PatentClassify . Sys PatentClassify, & out ) ; err != nil {
if err := model2 . Scan ( mTechnology PatentClassify . Technology PatentClassify, & out ) ; err != nil {
return nil , err
}
return c . ipcTree ( out , 0 ) , nil
@ -264,12 +282,12 @@ func (c *Patent) IPC() ([]*PatentIPCInfo, error) {
// IPCForm IPC数据操作
func ( c * Patent ) IPCForm ( params * PatentIPCParams ) error {
mSys PatentClassify := model . NewSys PatentClassify ( )
mTechnology PatentClassify := model . NewTechnology PatentClassify ( )
if params . ID > 0 {
mSys PatentClassify . ID = params . ID
mTechnology PatentClassify . ID = params . ID
isExist , err := model2 . FirstField ( mSys PatentClassify . Sys PatentClassify, [ ] string { "id" , "created_at" } )
isExist , err := model2 . FirstField ( mTechnology PatentClassify . Technology PatentClassify, [ ] string { "id" , "created_at" } )
if err != nil {
return err
@ -277,20 +295,20 @@ func (c *Patent) IPCForm(params *PatentIPCParams) error {
return errors . New ( "操作错误, IPC信息不存在或已被删除" )
}
}
mSys PatentClassify . SetIndustryDetailAttribute ( params . Industrys )
mTechnology PatentClassify . SetIndustryDetailAttribute ( params . Industrys )
// 查询上级元素
if params . ParentID > 0 {
mPSys PatentClassify := model . NewSys PatentClassify ( )
mPSys PatentClassify . ID = params . ParentID
mPTechnology PatentClassify := model . NewTechnology PatentClassify ( )
mPTechnology PatentClassify . ID = params . ParentID
isExist , err := model2 . FirstField ( mPSys PatentClassify . Sys PatentClassify, [ ] string { "id" , "industry" } )
isExist , err := model2 . FirstField ( mPTechnology PatentClassify . Technology PatentClassify, [ ] string { "id" , "industry" } )
if err != nil {
return err
} else if ! isExist {
return errors . New ( "操作错误, IPC父级信息不存在或已被删除" )
}
_identitys := mPSys PatentClassify . GetIndustryDetailAttribute ( )
_identitys := mPTechnology PatentClassify . GetIndustryDetailAttribute ( )
for _ , v := range params . Industrys {
if utils . InArray ( v , _identitys ) {
@ -298,32 +316,31 @@ func (c *Patent) IPCForm(params *PatentIPCParams) error {
}
_identitys = append ( _identitys , v )
}
mSys PatentClassify . SetIndustryDetailAttribute ( _identitys )
mTechnology PatentClassify . SetIndustryDetailAttribute ( _identitys )
}
mSys PatentClassify . ParentID = params . ParentID
mSys PatentClassify . IPC = params . IPC
mSys PatentClassify . SetIndustryAttribute ( params . Industrys )
mTechnology PatentClassify . ParentID = params . ParentID
mTechnology PatentClassify . IPC = params . IPC
mTechnology PatentClassify . SetIndustryAttribute ( params . Industrys )
if mSys PatentClassify . ID > 0 {
return model2 . Updates ( mSys PatentClassify . Sys PatentClassify, mSys PatentClassify . Sys PatentClassify)
if mTechnology PatentClassify . ID > 0 {
return model2 . Updates ( mTechnology PatentClassify . Technology PatentClassify, mTechnology PatentClassify . Technology PatentClassify)
}
return model2 . Create ( mSysPatentClassify . SysPatentClassify )
return model2 . Create ( mTechnologyPatentClassify . TechnologyPatentClassify )
}
// IPCDelete IPC删除操作
func ( c * Patent ) IPCDelete ( id uint64 ) error {
mSys PatentClassify := model . NewSys PatentClassify ( )
mSys PatentClassify . ID = id
mTechnology PatentClassify := model . NewTechnology PatentClassify ( )
mTechnology PatentClassify . ID = id
isExist , err := model2 . FirstField ( mSys PatentClassify . Sys PatentClassify, [ ] string { "id" , "created_at" } )
isExist , err := model2 . FirstField ( mTechnology PatentClassify . Technology PatentClassify, [ ] string { "id" , "created_at" } )
if err != nil {
return err
} else if ! isExist {
return errors . New ( "操作错误, IPC信息不存在或已被删除" )
}
return model2 . Delete ( mSys PatentClassify . Sys PatentClassify)
return model2 . Delete ( mTechnology PatentClassify . Technology PatentClassify)
}
func NewPatent ( ) PatentHandle {